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Editor's Page 



Formulating Our Product Review Policy 

Recently we received a letter that said: 
"I don't think you should do reviews for 
new products. This is what has hurt all the 
other magazines — their need to be current, 
trendy, with-it. The Computer Journal 
should be behind the times by supporting 
the end user after he or she has bought 
their system and then says "What Now?" 
It was a thought-provoking letter with some good 
points, and it made the staff here at The Computer 
Journal think a lot about our then-unstated product 
review policy. 

We feel that one of the purposes of a journal is to 
bring information on new product developments to 
the attention of the readers, but it is true that some 
magazines have reached the point where new product 
releases and product reviews take up the majority of 
the space. 

There is a difference between a product 
announcement, which is usually written from the 
vendor's literature, and a product review, which 
requires working with the product in an actual 
application long enough to find out how it really 
performs. A so-called "review" written from the 
manual with a quick run on the computer is useless. 

Our product information should follow in the same 
vein as the majority of our articles by providing 
specific technical information that will be of use to 
those who "build, interface, and apply micros." As a 
general rule, if it is covered in Byte and InfoWorld, 
we do not need to rehash the same information by 
covering it in The Computer Journal. 

The areas we intend to cover in our product 
reviews are utilities, languages, sensors, boards, 
interfaces, peripherals, etc. We may occasionally 
report on products which have been covered 
elsewhere, but we will concentrate on the technical 
aspects of the products and not just repeat what you 
have already read. 

A good review involves a lot of work, and we don't 
have the time to spend on products which do not 
interest our readers. We would appreciate your 
feedback on the subject of product reviews. Some of 



the products we have for review are: Conix (a CP 
enhancement), ACNAP (an AC circuit analysis 
program), PLOTPRO (a plotting program which 
works with ACNAP), SPP (a signal processing 
program), FORTH-83, and Condor-3. 

Tell us which ones we should eliminate, and 
suggest items that you think we should add to our 
list. We would also like to incorporate your 
experience with the product into the reviews, or use 
them as added comments in a future issue. 

Our policy henceforth will be to review technical 
products which are of interest to our readers, but to 
avoid reviewing systems and general interest items 
which are covered in other publications. We don't 
want to use an excessive amount of space for new 
product announcements and product reviews, but 
since other publications are not presenting the 
detailed technical reviews our readers demand, we 
will concentrate on presenting needed information. ■ 
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READING PCDOS DISKETTES 

WITH THE MORROW MICRO DECISION 



by Lance Rose, Technical Editor 

W ith all the different 5V« inch diskette formats around 
today, it's not surprising that there is little compatibility 
from one manufacturer's equipment to another, even within 
the realm of CP/M systems. Add to this the fact that aside 
from CP/M systems there is the IBM PC and its lookalikes 
with their own operating system known as PCDOS, and you 
have a real mess. 

Here at The Computer Journal we are constantly faced 
with the problem of potential articles being submitted on a 
variety of diskette formats and not always having the right 
machine around to read them on. Fortunately, we do have 
an 8-inch CP/M system and an Apple which helps quite a bit. 
Nevertheless, until recently we have been dependent on 
other facilities to read any diskette that came in written on 

a PC. 

Recently we acquired a Morrow Micro Decision with 
double-sided minifloppy drives. Morrow has thoughtfully 
provided several utility programs with the system that can 
enable the machine to read diskettes made on the Osborne, 
Xerox and IBM disk systems. The catch is that only the 
CP/M-86 format is supported for the PC. Unfortunately for 
us, PCDOS is the de-facto standard for the PC and almost no 
one uses CP/M-86 on it. The question was, how do we use 
' this utility to read files from a PCDOS diskette? 

Luckily, it turns out that PCDOS and CP/M-86 for the 
IBM PC both use the same type of physical diskette 
formatting, namely 512-byte sectors. Depending on which 
version of PCDOS we're talking about, there are eight 
(Version 1) or nine (Version 2) sectors per track. In addition, 
for the double-sided formats of PCDOS, the diskette is 
organized in cylinders. This means that track side is 
used first, then track side 1, followed by track 1 side 0, etc. 
Fortunately, this is the same arrangement used in the Micro 
Decision double-sided format. By simply running the 
IBM.COM utility to set drive B to an IBM drive and 
changing a byte in the drive description table we can also 
read double sided PCDOS diskettes. 

With the physical format compatibility problems handled 
by IBM.COM, we can turn our attention to the logical layout 
of PCDOS diskettes and how they differ from CP/M 
diskettes. In CP/M, each directory entry is 32 bytes long and 
contains the user number, file name and type, number of 
128-byte records in the file, and a list of up to 8 "allocation 
block numbers" which point to the areas of the diskette 
where the file is to be found. Since in many systems these 
blocks are 2K bytes each, the directory entry can represent 
files up to 16K in size. The problem here is that if the file is 
over 16K bytes long, we need a second directory entry to 
hold the additional allocation block numbers for the file. For 
example, a file that was 87K long would require 6 entries 



(192 bytes) in the directory to represent it. 

This isn't a very efficient use of directory space and it 
may be one reason that Microsoft chose a different directory 
format for their MSDOS/PCDOS operating system. In this 
system, there is a file allocation table (FAT) on track of 
each diskette. This table contains linked lists of the sectors 
allocated to each file. The directory, which is located on 
track immediately following the FAT, consists of 32-byte 
entries, like CP/M. Each entry contains the file name and 
type, file size in bytes, and a pointer into the file allocation 
table. This pointer identifies the first sector allocated to a 
file. The succeeding pointers are in the FAT itself, of course. 
The advantage here is that only two bytes are necessary in 
the directory entry itself to point to the linked list as 
opposed to 16 bytes for each CP/M entry. There are two 
immediate advantages to this. First, the additional bytes in 
the 32-byte directory entry can be used for time and date 
stamping which PCDOS supports. Secondly, only one entry 
is required no matter how large the file. 

With this in mind, and the PCDOS manual in hand, one 
can read the FAT and directory into memory, display the 
contents of the directory, and/or read a file from the 
diskette by following the linked list of allocated sectors 
using the mapping algorithm described in the PCDOS 
manual. 

Listing 1 is an assembly listing of a program that will 
read a PCDOS directory and display its contents in a format 
similar to the CP/M DIR command. In addition, the size of 
each file is also displayed, rounded up to the nearest Ik 
bytes. This allows the user to examine the PCDOS diskette 
in drive B and see what files, if any, he wants to transfer to 
the CP/M diskette in drive A. The program is run by typing: 
DIRPC (return). 

Listing 2 is an assembly listing of a program that searches 
the PCDOS directory for a given file and then, if found, 
copies it to the CP/M diskette in drive A. For example, if 
the user wants to copy a file named LETTER.TXT, he 
would type: READPC LETTER.TXT (return). A message is 
displayed if the file isn't found; otherwise the copy is made. 
When finished reading PCDOS diskettes, the program 
MORROW.COM can be run to set drive B back to a Morrow 
drive. 

These programs will work on both the Micro Decision MD- 
2 (single sided drives) and MD-3 (double sided drives) as long 
as the PCDOS diskette is single sided. In addition, if you 
have an MD-3, the program will detect double-sided PCDOS 
diskettes and read them as well. We plan to make good use 
of it here at The Computer Journal office. 

Although not our immediate goal, it would also be 
possible to go the other way, i.e. transfer CP/M files to a 
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PCDOS diskette. To do this, one would have to search the 
FAT for empty sectors and build the linked list as the file is 
transferred. Should any of our ambitious readers come up 
with such a program, we would very much like to hear about 
it. (Listings 1 and 2 follow.) 



Listing 1 



DIRPC.ASH 

Program to display d: 
IBM PCDOS diskette 
Decision, assuming 
to aet Drive B to t 

Version of 4/24/84 



BOOT EOU 


0000H 


BDOS EOU 


000 SH 


TBUFP EOU 


00B0B 


ORG 


100H 


LXI 


SP, STACK 


LDA 


BOOT+2 


STA 


SELDSK* 2 


STA 


SETTRK+2 


STA 


SETSEC +2 


STA 


SETDMA + 2 


STA 


READ-* 2 


KVI 


C,l 


CALL 


SELDSK 


KVI 


c,« 


CALL 


SETTRK 


MVI 


C,5 


CALL 


SET SEC 


CALL 


REAT 


ORA 


A 


JNZ 


BOOT 


LHLD 


BOOT+1 


LXI 


D.41H 


DAD 


D 


MOV 


E.M 


I NX 


H 


MOV 


D,M 


LXI 


H,9 


DAD 


D 


LXI 


D.FKTERR 


LDA 


TBUFF 


LXI 


B, 1C0DH 


INR 


A 


JZ 


DOUBLE 


MVI 


B.10H 


IKK 


A 


JZ 


SINGLE 


LXI 


B.1C1SH 


I BR 


A 


JZ 


DOUBLE 


KVI 


B, 10H 


INR 


A 


JNZ 


EXIT 


SINGLE: I NX 


B 


MCV 


A,M 


AMI 


0FBH 


MOV 


M,A 


JKF 


RDDIR 


DOUBLE: MOV 


A,H 


AN] 


20H 


JZ 


EXIT 


1NX 


H 


MOV 


A,M 


OR I 


B4H 


MOV 


M, A 


RDDIR: LXI 


H, DIRBUF 


RDDIR1: PUSH 


B 


PUSH 


H 


CALL 


SETSEC 


POP 


B 


PUSH 


B 


CALL 


SET DMA 


CALL 


READ 


POP 


H 


POP 


B 


ORA 


A 


J HZ 


BOOT 


PUSH 


H 


LXI 


H.-0920H 


DAD 


B 


MOV 


A, H 


ORA 


L 


JZ 


RDDIR 2 


LXI 


B, -0D24R 


DAD 


B 


MOV 


A,H 


ORA 


L 


JNZ 


RDDIR 3 


RDD1R2: PUSH 


B 


KVI 


C.i 


CALL 


SETTRK 


POP 


B 


KV] 


C.0 


RDDIR3; POP 


a 


LXI 


D.12B 


DAD 


D 


IsTF 


C 


DCR 


B 


JNZ 


RDDIR 1 


MOV 


A.H 


LXI 


B, DIRBUF 


SUB 


K 


ADD 


A 


ADD 


A 


ADD 


A 


MOV 


C.A 


wrraiT: MOV 


A,H 


CP1 




JC 


mPTY 


CPI 


7PH 


JVC 


EMPTY 


PUSH 


B 


PUSH 


H 



rectory and file sice of an 
in Drive B of a Morrow Micro 
1BM.COM has already been run 
n IBM type diskette 



CP/M reboot address 
BDOS entry point 
Transient disk buffer 



;Set up local stack 
[Patch for BIOS calls 



[Select P drive 
;Set track e 



rSet logical sector 5 
;Read first part of PAT 



;Read error 

rLocate drive table (MTAB) 



:BX pointe to drive B entry 
;ln c«Be unreadable 
,-Get first byte of FAT 
rSector count L first sector 

;DOS 1.0 double sided 



;D0S 1 .0 single sided 

rDOS 2.0 double Bided 

;Not DOS 2.0 single sided 

; Set media bit to sing 1 e sided 



;Test oouble sided drive bit 
; Single sided drive , no read 



rMark nedia double sided 

[Point at directory buffer 
[Save sector 
;Save DMA address 



;Exit if disk error 



;Go to neit side 



[Stay on save side 
:Go to track 1 

; Start with sector 1 

;Go to next DMA address 

:Next sector 

: Decrease sector count 

(Calculate directory «nr 
;8 entries per page 
rMaxisiua entries in C 

:Not printing ASCII 

rSame, assume capty 
;Save count 
;Savf pointer 





nuv 
AMI 


A.B 

03R 






JVZ 


MIDLIN 






LXI 


D.CRLP 






CALL 


DSPLY 


;Do a CRLP at beginning 




JMP 


DSPENT 


rSkip separator 


MIDLIN: 


MVI 


E.M' 


[Display separator be twee 




CALL 


WRTCON 






CALL 


SPACE 


{Add a space 


DSPENT 


POP 


H 


r Restore entry pointer 




PUSH 


H 






MVI 


c,e 


r Filename characters 




CALL 


NAME 


i Di spl ay f i lename 




CALL 


SPACE 


(Separate with apace 




KVI 


C,3 






CALL 


NAME 


[Display filetypc 




CALL 


SPACE 


[Trailing apace 




LXI 


D,17 






DAD 


D 


; Point at file sine 




MOV 


E.M 


[Get sice in registers 




I NX 


H 






MOV 


D,M 






not 


H 






MOV 


A.M 






LXI 


H. 3FFH 


[Round up to nearest Ik 




DAD 


D 






AC1 









MOV 


L.H 


[Shift right 10 bits 




NOV 


a, a 






MVI 


C.2 




SB 1 FTP 


XRA 


A 






MOV 


A.H 






RAP 








MOV 


H, A 






MOV 


A,L 






RAR 








MOV 


L,A 






DCR 


C 






JVZ 


SHIFTR 






XRA 


A 






STA 


NONZRO 


;Non-tero flag 




LXI 


D.-1B0 






CALL 


DIGIT 


[Display hundreds 




LXI 


D.-10 






CALL 


DIGIT 


[Display tens 




MOV 


A,L 






AD I 


'•0' 






MOV 


E,A 






CALL 


WRTCON 


[Display ones 




KVI 


E, *k - 


;Add 'k' to sise 




CALL 


WRTCON 






CALL 


SPACE 


[Add a trailing space 




POP 


H 






POP 


B 






INR 


B 




em pry : 


LXI 


D,32 






DAD 


D 


;Go to next entry 




DCR 


C 






JNZ 


NXTENT 


[More entries to check 




MOV 


A,B 






ORA 


A 






LXI 


D.NOFILE 






JZ 


EXIT 


rNo entries 




LXI 


D.CRLF 


;At least one entry 


EXIT: 


CALL 


DSPLY 


[Display Message 




JMP 


BOOT 


; Reboot 


DSPLY : 


MVI 


C,9 


; Display string function 




JMP 


BDOS 




SPACE: 


MVI 


E, ' ' 


[Diaplay space 


WRTCON 


PUSH 


B 






PUSH 


H 






MVI 


C, 2 


[Write console function 




CALL 


BDOS 






POP 


H 






POP 


B 






RET 






NAME: 


MOV 


E.M 






CALL 


WRTCON 






INX 


R 






DCR 


C 






JNZ 


NAME 






RET 






DIGIT: 


MVI 


A, '0'-l 


[Initialize digit 


D1GIT1 : 


DAD 


D 


r Divisor in DE 




INR 


A 


[ASCII digit in A 




JC 


DIGIT1 






PUSH 


PSW 


[Save digit 




MOV 


A,L 






SUB 


E 


rCorrect for overflow 




MOV 


L.A 






MOV 


A.H 






6BB 


D 






MOV 


H,A 






POP 


PSW 






MOV 


E,A 


jDigit in E 




CPI 


■0* 






JZ 


DIGIT2 


;z>ero in this place 




MVI 


A.0PFB 






STA 


NONZRO 


[Set flag 




JMP 


WRTCON 




DlGlT2j 


LDA 


NONZRO 






ORA 


A 






JNZ 


WRTCON 


[Display embedded zero 




MVI 


E, ' 


; Suppress leading ceros 




JMP 


WRTCON 




SELDSK : 


JMP 


001BH 


[Values are filled in 


SETTRK: 


JMP 


M1EH 




SETSEC : 


JMP 


0021H 




SET DMA; 


JMP 


M24H 




READ: 


JMP 


0027H 




FMTERR ; 


DB 


'••• UNREADABLE 


PCDOS FORMAT *•"' 




DB 


•DH.0AH.07H, '$' 




NOF1LE: 


DB 


0DH.0AH, 'MO FILE 




CRLP: 


DB 


•DH , 0AH , ' $ ' 




HONZRO: 


DS 


1 


[Flag for non-zero value 



DIRBUF: DS 



4B :Stack area 

$ 

l$*0PPB) AND 0FP00H 

7«200H ;PCDOS directory 
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Listing 2 



READPC.ASM 

Prograr. to copy a file fro. an IBH PCDOS aiakette 
in Drive B to a CP/M file or, Drive * of a Horrov 
Micro Deci.ion. aeeu»in<| IBH.COM ha. already 
been run to »et Drive B to an IBH type diekette 

Version of 4/24/B4 

;CP/M reboot addreaa 
tBDOS entry point 
;Deatination FCB 



BOOT EQU 


M00B 


BDOS EQU 


000 5H 


DGTFCB EQU 


•0SCH 


ORG 


HA- 


I 

LXJ 


SP, STACK 


LDA 


BOOT* 2 


STA 


SELDSK4 2 


ETA 


SETTRX+2 


STA 


SETSEC+2 


ETA 


BETDHA+2 


STA 


READ+2 


KVI 


C.l 


CALL 


SELDSK 


KVI 


C.0 


CALL 


SETTRK 


LXI 


B.040SH 


LXI 


H.FAT 


RDF AT : PUSH 


B 


PUSH 


H 


CALL 


6ETSEC 


POP 


B 


PUSH 


B 


CALL 


SET DMA 


CALL 


REAL. 


POP 


H 


POP 


B 


ORA 


A 


JUL 


BOOT 


LXI 


D, 126 


DAr 


D 


IH* 


C 


DCR 


B 


JNZ 


RDFAT 


LHLD 


BOOT+1 


IJt] 


D,41H 


DAD 


D 


NOV 


E,M 


1KX 


H 


NOV 


D.H 


LXI 


H,9 


DAP 


D 


XCHG 




LDA 


FAT 


LXI 


b, iceoif 


LXI 


H.0608H 


1MB 


A 


JZ 


DOUBLE 


KVI 


B, IBH 


LXI 


k, ba:bh 


INK 


A 


JZ 


SINGLE 


LXI 


B, 1C1SH 


LXI 


H,0B09H 


INP 


A 


JZ 


DOUBLE 


KVI 


B, IBH 


LXI 


H.0F12H 


INK 


A 


JZ 


SINGLE 


NOREAD : LX 1 


D, FKTEKB 


JMF 


EXIT 


SINGLE: INX 


D 


LDAX 


r 


AN I 


Br'BH 


ST AX 


D 


KVI 


A,B3H 


JMF 


RDDIR 


DOUBLE : LDAX 


D 


AMI 


20H 


JZ 


NOREAD 


1KX 


P 


LDAX 


D 


OR1 


04 H 


ST AX 


D 


KVJ 


A.B7H 


RDDIR: STA 


CLMASK 


SHLD 


SPT 


LXI 


H.DIRBUF 


RDDIR 1: PUSH 


B 


PUSH 


H 


CALL 


SETSEC 


POP 


B 


PUSH 


B 


CALL 


SET DMA 


CALL 


READ 


POP 


H 


POP 


B 


ORA 


A 


JHZ 


BOOT 


PUSH 


B 


LXI 


H.-0920H 


DAD 


B 


NOV 


A,H 


ORA 


L 


JZ 


RDDIR 2 


LXI 


H.-0D24H 


DAD 


B 


NOV 


A,H 


ORA 


L 


JHZ 


RDDIR3 


RDD1R2: PUSH 


B 


KVI 


C,l 


CALL 


SETTRK 


POF 


B 


KVI 


c,e 


RDD1R3: POP 


H 


LXI 


D.128 


DAD 


D 


IHR 


C 


DCR 


B 


JHZ 


RDDIR] 


MOV 


A.B 


LXI 


H.DIRBUF 


SUB 


H 


ADD 


A 


ADD 


A 



;Set up local stack 
.Patch for BIOS call* 



.Select B drive 

(■Set track 
-Read FAT 

;Save sector 
:Save DMA address 



:Reboot if disk error 

:Go to next DMA address 

;Ne*t sector 

rDecrease sector count 

.-Locate drive table (MTAB) 



;DF points to drive B entry 
;G«-t first byte of FAT 

iSerto: count 4 first sector 
;CLOKF and SPT 

;DOS 1.0 double Bided 



;DOS 1.0 single sided 



;DOS 2.0 double sided 



; DOS 2.0 singlf sided 
;Unreadable 



;Set »ed is bit to Binqle sided 
:Mask 



;Test double tided drive bit 
:S»ngle sided drive, no read 



rk siedia double sided 



;Double sided mask 

;Save forsiat info 

;Point at directory buffer 

;Save sector 

;Save DMA address 



:Exit if diBk err 



;Go to next side 



.Stay on sa»e side 
:Go to track 1 

; Start with sector 



;Go to next DMA address 

;Hext sector 

; Deer ease sector count 

rCalculate directory site 



entries per page 



ADD 


A 


MOV 


B,A 


LXI 


D.DSTTCB+l 


SEARCH i PUSH 


D 


PUSH 


B 


KVI 


C,ll 


COMPAR: LDAX 


D 


CMP 


M 


JVZ 


DIFFER 


IHX 


D 


irx 


H 


DCR 


C 


JHZ 


COM PAR 


JKP 


POUHD 


DIFFER: POP 


B 


LXI 


D,32 


DAD 


D 


POP 


D 


DCR 


B 


JHZ 


SEARCH 


LXI 


D.PNFERR 


JMP 


EXIT 


POUHD: POP 


D 


XTRL 




KVI 


C.0 


CALL 


SELDSK 


LXI 


D.DSTPCB 


KVI 


A.l 


ST AX 


D 


PUSH 


D 


KVI 


C.19 


CALL 


BDOS 


POP 


D 


KVI 


C.22 


CALL 


BDOS 


1NR 


A 


LXI 


D.DDFERR 


JZ 


EXIT 


POP 


H 


LXI 


D,15 


DAD 


D 


MOV 


E,K 


1KX 


H 


MOV 


D,M 


INX 


H 


XCHG 




SHLD 


CLUSTR 


XCHG 




KOV 


E,N 


INX 


B 


NOV 


D,K 


INX 


H 


NOV 


A,H 


LXI 


H.7FH 


DAD 


D 


AC1 


e 


DAP 


H 


RAL 




MOV 


L,H 


MOV 


H.A 


LXI 


D.DATBUF 


KVJ 


C,0 


LOOP: KOV 


A.H 


ORA 


L 


JNZ 


MORE 


CALL 


FLUSH 


LXI 


D.DSTFCB 


KVI 


C,16 


CALL 


BDOS 


JMP 


BOOT 


MORE: PUSH 


B 


PUSH 


B 


PUSH 


D 


LDA 


CLMASK 


ANA 


C 


JVZ 


CURRNT 


LHLD 


CLUSTR 


XRA 


A 


KOV 


A.H 


RAR 




MOV 


D, A 


MOV 


A.L 


RAR 




MOV 


E, A 


PUSH 


PSM 


DAD 


D 


LXI 


C.PAT 


DAD 


D 


MOV 


E,K 


INX 


H 


MOV 


D,M 


POP 


PSM 


MV1 


C.4 


JC 


ODD 


KOV 


A,D 


AHI 


0FH 


KOV 


D,A 


JKP 


UPDATE 


ODD: XRA 


A 


KOV 


A,D 


RAR 




MOV 


D,A 


KOV 


A.E 


RAR 




MOV 


E,A 


DCR 


C 


JHZ 


ODD 


UPDATE: LHLD 


CLUSTR 


XCHG 




SHLD 


CLUSTR 


LHLD 


CLOFF 


KVI 


H.P 


XCBG 




DAD 


H 


DAD 


D 


LDA 


SPT 


CHA 




IHR 


A 


NOV 


E.A 


NV1 


D , 0FFH 


KOV 


CD 


DIVIDE: DAD 


D 


IHR 


C 


JC 


DIVIDE 


LDA 


CLMASK 


IMR 


A 


WC 





.Masiauxt entries in B 
iPoint at filename 
;6ave pointers 

[Length of filen*a.e/typ* 

.Hot the sa»e 

.Entry avatched 
;Go to next entry 

; Hot found 

; Balance stack 

F Save pointer to entry 

:Destination is always A 
.Delete old file if present 
;Kake new file 



;Dlsk full 
;Reatore pointer 



f Point to 1st cluster 



.-Save next cluster 
tGet file site 



iConvert to logical records 



:Record count in HL 
;Buffer pointer in DE 
;Buffer records in C 



:More records in file 
;Flush data buffer 



;Close file 

;Done 

;Save parameters 

;Get xtask 

.-Disk and track current 



.-Save odd/even status 

;HL point at next cluster 

;DE have next cluster nusiber 

;Bit count 

[Previous cluster was odd 

;Keep only lowest 12 bits 



rClear carry 

;Keep highest 12 bits 



;Get current cluster 
;Replace with next cluster 



;Cluster*2 

; Compute track/sector frost BL 



;Divide HL by *pt 
iTrack in C 



continued 
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SELDSK: 

settrk 

setsec 

SET DMA 

READi 



MtC 
MOV 

MOV 
SUB 
ADD 
NOV 
MOV 
RJtC 
MOV 
MOV 
JHC 

in 

STA 

MOV 
STA 
CALL 
MVI 
CALL 
: LDA 
CP1 
JC 
LDA 

lira 

MOV 
CALL 
MVI 
MOV 
XtfR 
STA 
CALL 
POF 
PUSH 
CALL 
CALL 
OR* 
JHZ 
POP 
LX1 
DAD 
XCHG 
POP 
DCX 
POP 
IHR 
CM 
JMP 
INR 
DCB 
R2 
PUSH 
PUSH 
MVI 
CALL 
POP 
LX1 
PUSH 
PUSH 
PUSH 
MVI 
CALL 
LX1 
MVI 
CALL 
LX1 
ORA 
JHZ 
POP 
POP 
LX1 
DAD 
XCHG 
DCB 
JB2 
POP 
POP 
RET 
MVI 
CALL 
JMP 
: JMP 
: JMP 
s JMP 
; JMP 
JMP 



PMTERR: DB 

DB 

PH7ERR: DB 

DDPERK: DB 

DB 

SPT: DS 

CLOFF : DS 

CLMASK: DS 

CLUSTRt DS 

TRACK: DS 

SECTOR: DS 

DS 

STACK EOU 



PAT: 

D1RBUP: 
DATBUF: 



Listing % continued 



B,A 

A,L 



B,A 

A,E 

MULT 

A 

SECTOR 

A,C 

TRACK 

SETTRK 

C, 1 

SELDSK 

SECTOR 

37 

1100 VF 

TRACK 

A 

C,A 

SETTRK 

A,l 

C,A 

A 

SECTOR 

SETSEC 



SET DMA 
READ 



FLUSH 
LOOP 



c,e 

SLLDSK 



C,26 

BDOS 

D.DSTPCB 

C,21 

EDOS 

D, DDPERR 

A 

EXIT 



; Remainder in A 
.•Multiply by »esk+l 



; First sector is tl 
t Update sector 



; Update track 
rSet nev track 



[Select next sector 
;No track overflow 



1G0 to next track 
rStart with sector 1 



fSet next DMA address 

;Read error 

:Go to next buffer area 
r Restore record counter 

;Flush data buffer if 128 
;Flush data buffer 
;Buf f er esipty 



C,9 

BDOS 

BOOT 

00 1 BP 
Ml EH 
0021H 
0024H 
002 7B 



rSet DMA address 



rWrite the r*cord 



rGo to next record 



[Display Message 

; Reboot 

rValues are filled 



* UNREADABLE PCDOS FORMAT •**' 
,0AH,07H, •$* 

* FILE NOT FOUND • •• ' , 0DH , 0AH, 07H, ' S ' 

* DISK OR DIRECTORY FULL •••' 
,0AH,07H, '$ ' * 

; Z^Sectors/track 

: 2*Cluster offset 

;Cluster stask 

[Next cluster 

j Cur rent logical track 

;Bext logical sector 

r Stack area 



(5+0PFH) AND 0FF00B 



1*200H 
7»200H 
4000B 



;Pi le allocation table 
; PCDOS directory 
;Dsta buffer 



Customer Support Survey 

In order to Improve customer support In the 

microcomputer Industry, TCJ will publish user 

experiences with vendors. Send us your 

candidates for the best and worst vendor, along 

with your supporting Information. 



MicroMotion 



MasterFORTH 

It's here — the next generation 
of MicroMotion Forth. 



• Meets all provisions, extensions and experimental 
proposals of the FORTH-83 International Standard. 

• Uses the host operating system file structure (APPLE 
DOS 3.3 & CP/M 2.x). 

• Built-in micro-assembler with numeric local labels. 

• Afull screen editor is provided which includes 1 6 x 
64 format, can push & pop more than one line, 
user definable controls, upper/lower case key- 
board entry, A COPY utility moves screens within & 
between lines, line stack, redefinable control 
keys, and search & replace commands 

• Includes all file primitives described in Kernigan 
and Plauger's Software Tools. 

• The input and output streams are fully redirectabte 

• The editor, assembler and screen copy utilities are 
provided as relocatable object modules. They 
are brought into the dictionary on demand and 
may be released with a single command. 

• Many key nucleus commands are vectored. Error 
handling, number parsing, keyboard translation 
and so on can be redefined as needed by user 
programs. They are automatically returned to 
their previous definitions when the program is 
forgotten. 

• The string-handling package is the finest and 
most complete available. 

• A listing of the nucleus is provided as part of the 
documentation, 

• The language implementation exactly matches 
the one described in FORTH TOOLS, by Anderson 
& Tracy. This 200 page tutorial and reference 
manual is included with MasterFORTH 

• Floating Point & HIRES options available. 

• Available for APPLE ll/ll+/lle & CP/M 2.x users. 

• MasterFORTH -$100.00. FP& HIRES -540.00 each 

• Publications 

• FORTH TOOLS - $20.00 

• 83 International Standard - $15.00 

• FORTH-83 Source Listing 6502, 8080, 8086 - 
$20.00 each. 




Contact: 

MicroMotion 

12077 Wilshire Blvd.. Ste. 506 

Los Angeles, CA 90025 

(213) 821-4340 
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WRITE YOUR OWN THREADED LANGUAGE 

by Douglas Davidson 



X he FORTH language presents a method remarkable for 
its simplicity, economy, and power; it should be 
remembered, however, that FORTH proper is but one 
example of the method referred to as threaded language. 
The characteristics of threaded languages make them 
particularly useful to hobbyists and all those who like to get 
close to the machine they are working with; it is my 
contention that the project of writing such a language is 
useful, educational, very much in the spirit of the language, 
and at the same time not very difficult. I will present in 
these articles a practical guide to the writing of one 
particular threaded language with the intention that it be 
customized and altered at will. This language is very similar 
to FORTH, but varies from it in a number of ways for the 
purposes of simplification. 

A threaded language consists essentially of a collection of 
tools and some facilities for using and adding to these tools. 
The basic tools are simple routines to do things such as 
simple arithmetic operations, input and output, etc. The 
tools communicate by means of a LIFO (last in, first out) 
stack which forms the heart of the apparatus; most routines 
are defined in terms of their effects on the stack, and 
arithmetic operations are presented in RPN form (for an ex- 
planation of RPN, see the tint box on page 30.) The power of 
the language comes from its extensibility: new routines are 
defined in terms of old ones, and then become part of the 
tool collection, and can in turn be used in the definition of 
still more routines. This is the origin of the term "threaded:" 
routines are stored essentially as lists of references to other 
routines, which are "threaded" together. Before introducing 
specifics, I would like to present a list of definitions. 

• Word: A named routine, consisting of a header followed 
by machine language code or data of some sort. See Figure 

1. 

• Primary: A word written in machine language; more 
generally, a word without a higher-level definition. 

• Secondary: A word defined in higher-level terms — that is, 
in terms of other words. In this presentation the distinction 
between primary and secondary will be somewhat blurred 
by the fact that secondaries will actually consist of machine 
code, but this is not always the case, and the difference will 



NFA 



LEN 



03 



NAME 



C4 D5 DO 



PFA 



LINK 



03 OB 



-v 



NFA 



CODE 



E6 00 ... 



-V 



LEN 



04 



NAME 



CF D6 C5 



Figure 1: Section of the Dictionary. 



still be clear. 

• Dictionary: The linked list of words. Words will be stored 
one after the other in memory; each one will contain a link 
to the previous one, and a record will be kept of the location 
of the last one. 

• Header: The housekeeping information at the head of a 
word, here consisting only of the word's name and a link to 
the previous word in the dictionary. The name will be stored 
as its first three characters in ASCII form, preceded by its 
length — this is somewhat standard, and should be sufficient. 
The link follows the name and is two bytes, the NFA of the 
previous word. 

• NFA: The name field address of a word -the address of 
the first byte of the header. 

• LFA: The link field address of a word -the address of the 
fifth byte of the header, equal to NFA + 4. 

• PFA: The parameter field address of a word — the address 
of the first byte following the header, equal to NFA + 6. 

I wish to present the language from the bottom up; I will 
start with the simplest routines, the ones that must be 
coded first, and proceed through the more complex, 
developing details as needed. The routines will be presented 
in several ways — a functional description will be given in 
the text, and the 6502 assembly and machine code for an 
Apple II implementation will follow. The presentation here 
may be conformed to on at least four different levels: the 
machine code level, preserving all memory locations, and 
using an Apple; the assembly level, for another 6502 
computer; the logic of the routines, translated into a 
different assembly language; or the functional descriptions 
of the routines. Obviously, it will be more of a personal 
language and easier to customize if it conforms less strictly 
to what is presented here, but the choice is yours. What is 
presented here is a bare-bones version, with all of the 
interfaces specified and the bugs ironed out. The memory 
map, at least for now, will be relatively simple. The 
dictionary will start near the bottom of memory and grow 
up; the stack will start near the top of memory (some room 
will be needed above it) and grow down; see Figure 2. Some 
space will also be needed for system variables. We will need 
a two-byte variable, S, to point to the head of the stack; as 

each stack entry will 
consist of two bytes, S 
will be incremented or 
decremented in multiples 
of two. I now postpone 
details of more complex 
things to get right to 
some basic routines. 
The first necessity is a 



IFA 



PFA 



LINK 



16 0B 



CODE 



E6 00 
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start-up routine, but since 
we do not yet know all that 
needs to be done, it would 
be best to simply put a jump 
instruction at the start of 
the program and leave its 
destination for later. Im- 
mediately after that we 
start adding words to the 
dictionary; each consists of a 
header — one byte of name 
length, three bytes of name, 
and two bytes of link — 
followed by the machine 
instruction 











1 
J 

, 

low 


ft-STACK 




INWT IUFFH 




HACK 


SECOND IUFFEA 


DICTIONARY 






Figure 2: Memory Map. 





code, ended with a return 
The link of the first word should be zero. 



Stack Manipulation: 

DROP removes the top stack element; it simply 

increments S by two. 

DUP duplicates the top stack element; it decrements S by 

two, then moves the two bytes starting at S + 2 to the two 

bytes starting at S. 

OVER places a copy of the second stack entry on top of 

the stack; it decrements S by two, then moves the two bytes 

starting at S + 4 to the two bytes starting at S. 

SWAP exchanges the top two stack elements; it 

exchanges the two bytes starting at S with the two bytes 

starting at S + 2. 

ROT cyclically exchanges the top three stack elements; it 

exchanges the two bytes starting at S + 2 with the two at 

S + 4, then the two at S with the two at S + 2. 

> R It will be useful for several reasons to maintain a 

second stack, the "return" stack, similar to but smaller than 

the first, and starting at the top of available memory and 

growing down. A two-byte variable, R, will point to the head 

of the return stack. The word > R moves the head of the 

main stack to the return stack; it decrements R by two, 

moves the two bytes at S to the two at R, and increments S 

by two. 

R> This word is the opposite of > R; it decrements S 

by two, moves the two bytes at R to the two at S, then 

increments R by two. 

I copies the head of the return stack to the main stack; it 

decrements S by two, then moves the two bytes at R to the 

two at S. 

Comparison: 

0= We will use a "flag" to indicate logical values; 
$0001 -= true, $0000 - false. All comparison operators will 
return these values, but for other purposes any non-zero 
value will be considered true. Also, it is conventional for 
words to destroy their operands; thus, the word checks the 
value at the head of the stack and replaces it with a true 
flag if it is zero, or a false flag otherwise. 
< Stack values will be considered for different purposes 
as logical values, as two's complement values, as ASCII 
values, or as unsigned binary values. The word 0< takes 
the top stack value as a two's complement signed integer; it 



replaces the top stack entry with a true flag if its most 
significant bit is high, otherwise with a false flag. 
=s Words, as I have said, destroy their operands; the - 
word determines a flag, a true flag if the top two stack 
entries (i.e., the two bytes at S and the two bytes at S + 2) 
are equal and a false flag otherwise, then increments S by 
two and replaces the two bytes starting at S by the flag 
previously determined. 

^ considers the two top stack entries as two's 
complement signed binary integers and determines a flag, 
true if the first one (the two bytes starting at S + 2) is less 
than the second (the two bytes starting at S) and false 
otherwise, then increments S and replaces the two bytes 
starting at S with the flag previously determined. <> is 
similar to ^ , if "less than" is replaced by "greater than". 

Logical: 

AND forms this bitwise logical AND of the two bytes 

starting at S with the two bytes starting at S + 2, 

increments S by two, then replaces the two bytes starting at 

S with the result of the logical operation. 

OR is similar to AND, but the operation is an OR. 

XOR is similar to AND, but the operation is an exclusive- 

or. 

NOT replaces the two bytes starting at S with their logical 

complement. 

Arithmetic: 

+ finds the sum of the two top stack entries, increments S 
by two, and replaces the two bytes starting at S with the 
sum. 

— is similar to + , but the difference rather than the sum 
is calculated; note that no overflow checking is performed. 
NEGATE replaces the top stack entry by its two's 
complement additive inverse; essentially it exclusive-ors the 
two bytes with $FFFF and then increments them by one. 
ABS replaces the top stack entry by its absolute value; if 
the MSB is high, it calls NEGATE, otherwise it does 
nothing. 

* It is wise, for the multiplication and division words, to 
reserve about ten bytes for accumulators, and to have 
headerless routines (a) to move stack values into these 
accumulators, taking their absolute values first and saving 
the final sign elsewhere, (b) to move a value from the 
accumulator to the stack, giving it the saved sign, and (c) to 
perform operations on the accumulators. The * word takes 
the two top stack entries, considered as two's complement 
binary integers, removes them from the stack, forms their 
product, and places it on the stack. 

is similar to *, but it forms the quotient (of the first value 
divided by the second) rather than the product. 
/MOD considers the two top stack values as unsigned 
binary integers, takes them off the stack, forms their 
quotient and remainder, and puts first the remainder, then 
the quotient on the stack. 

MOD is similar to /MOD, but it discards the quotient and 
returns just the remainder. 
•/ takes the three top stack entries, considered as two's 
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complement binary integers, off the stack, forms the 32-bit 
product of the first two, and divides this 32-bit product by 
the third. It then places the resulting 16-bit value back on 
the stack. 

•/MOD is similar to */, but it considers the entries as 
unsigned binary values, and it returns first a remainder and 
then a quotient. 

Memory: 

1 takes the value in the two bytes starting at S + 2 and 

stores it in the two-byte location pointed to by the two bytes 

starting at S; it then increments S by four. 

+ 1 takes the value in the two bytes starting at S + 2 and 

adds it to the two-byte value pointed to by the two bytes 

starting at S, then stores the sum in the location pointed to 

by the two bytes starting at S; it then increments S by four. 

C! takes the value in the one byte starting at S + 2 and 

stores it in the one byte pointed to by the two bytes 

starting at S; it then increments S by four. 

@ replaces the two bytes starting at S with the two bytes 

they point to. 

C@ replaces the two bytes starting at S with the one byte 

they point to and a $00 for the upper byte. 

The next installment will present more complex routines, 
including most of the input-output and dictionary 
management. For now, test each of these simple routines 
independently, and perhaps add some more — anyone 
familiar with FORTH will know several more. The purpose 
of some of these routines will become clearer as things 
progress. 



• • S**Af •• 



** CODE FOR 


SAMPLE 


THREADED 


-ANGUAGE 


.. 


• • 




APPLE / 


1 1650: 






** 


0600 


4c 16 


13 








JHF 


STARTUP 










•• 


DROP • 


* 






0603' 


04 C4 


D2 


CF 


00 


00 








060? 


E6 00 










INC 


SL 


; mcrfgnt 5 by 2 


060B: 


D0 02 










BNE 


OKI 




080D 


E6 01 










INC 


SH 




080F: 


E6 00 




OK 1 






INC 


SL 




0611 


D0 02 










BNE 


OK2 




0613- 


E6 01 










INC 


SH 




0815 


60 




OK2 






RTS 












•• 


DUP •• 








•616: 


03 C4 


D5 


M 


03 


•e 








061C: 


E6 00 










INC 


SL 


J dvcrvwnt S by 2 


061E: 


C6 00 










DEC 


SL 




•620: 


D0 02 










BNE 


D> 1 




•6??: 


C6 01 










DEC 


SH 




•624: 


C6 «0 




OKI 






DEC 


SL 




•626: 


D0 02 










BNE 


0*2 




•628: 


C6 01 










DEC 


SH 




062A: 


C6 00 




OK2 






DEC 


SL 




062C: 


A0 03 










LDV 


•»03 


; aovi the two bytes 


06 2E: 


Bl 00 










LDA 


<S> , V 


; at S + 2 


•630: 


A0 01 










LDV 


•*01 


; to the txo bytes 


0632: 


91 00 










STA 


<S> , V 


i At S 


•634: 


C8 










INV 






0635: 


Bl 00 










LDA 


<S> ,Y 




0637: 


A0 00 










LDV 


• •00 




•639: 


91 00 










STA 


(SI , V 




063B: 


60 










RTS 












*• 


OVER * 


• 






06 3C: 


04 CF 


D6 


C5 


16 


06 








•642: 


E6 00 










INC 


SL 


; dvcrtMent S by 2 


•644: 


C6 00 










DEC 


SL 




•646: 


D0 02 










BNE 


OK 1 




0648: 


C6 01 










DEC 


SH 




064A: 


C6 00 




OKI 






DEC 


SL 




•64C: 


D0 02 










BNE 


OK2 




064E: 


C6 01 










DEC 


SH 




0650: 


Cb 00 




OK2 






DEC 


SL 




0652: 


AC 05 










LDV 


• •05 


; Mvt the two bytes 


0654: 


Bl 00 










LDA 


(S) , Y 


f at S+4 


0836: 


A0 0) 










LDV 


••01 


f to the two bytes 


0656: 


91 00 










STA 


<S) ,Y 


1 at S 


065A: 


A0 04 










LDV 


••04 




065C: 


Bl 00 










LDA 


<S> , v 




065E: 


A0 00 










LDY 


••00 




066« : 


91 00 










STA 


(S) , V 




0662: 


60 










RTS 







0663: 


04 


D3 D7 


CI 3C 08 








0669: 


A0 


03 




LDY 


••03 


t exchange the two 
bytes 


066B: 


Bl 


00 




LDA 


(S) , Y 


i at S+2 with 


066D: 


AA 






TAX 




; the two bytes at S 


086E: 


A0 


01 




LDY 


■ *01 




0670: 


Bl 


00 




LDA 


(S> ,Y 




0672: 


A0 


03 




LDY 


• •03 




0674: 


91 


00 




STA 


(SI ,Y 




0676: 


A0 


01 




LDY 


••01 




0676: 


BA 






TXA 






0679: 


91 


00 




STA 


<S>,Y 




067B: 


C8 






INY 






067C: 


Bl 


00 




LDA 


<S) , Y 




067E: 


AA 






TAX 






067F: 


A0 


00 




LDY 


• •00 




06B1 : 


Bl 


00 




LDA 


<S> , Y 




0663: 


A0 


02 




LDY 


•S02 




0685: 


91 


00 




STA 


<S> .V 




0687: 


A0 


00 




LDY 


••00 




0669: 


BA 






TXA 






066A: 


91 


00 




STA 


<S> ,Y 




06BB: 


60 




** ROT •• 


RTS 






088D: 


03 


D2 CF 


D4 63 08 








0893: 


E6 


00 




INC 


SL 


; swap the tHo bytes 


0895: 


D0 


02 




BNE 


OKI 


; at S+4 with the 


0897: 


E6 


01 




INC 


SH 


; two bytes at S+2 


0899: 


E6 


00 


OH 


INC 


SL 




089B: 


D0 


02 




BNE 


OK 2 




089 D: 


E6 


01 




INC 


SH 




069F: 


20 


69 08 


Ot 2 


JS* 


SWAP 




08A2: 


E6 


00 




INC 


SL 


■ then «MdD the two 


06A4: 


C6 


00 




DEC 


SL 


i bytes at S+2 


08A6: 


D0 


02 




BNE 


OK3 


; with the two bytes 


08AB: 


C6 


01 




DEC 


SH 


> at S 


06AA: 


C6 


00 


ok 3 


DEC 


SL 




06AC: 


D0 


02 




BNE 


OK4 




06AE: 


C6 


01 




DEC 


SH 




08f<0: 


C6 


00 


OK 4 


DEC 


SL 




08 B2: 


4L 


69 08 


*• >R •• 


JMP 


SWAP 




06B5: 


02 


BE D2 


A0 8D 08 








•6B&: 


E6 


02 




INC 


RL 


; decrement R by 2 


0BBD: 


Cb 


02 




DEC 


RL 




06 BF: 


D0 


02 




BNE 


OKI 




08C1: 


C6 


QZ 




DEC 


RH 




06C3: 


C6 


02 


OKI 


DEC 


RL 




06C5: 


D0 


02 




BNE 


OK2 




08C7: 


C6 


03 




DEC 


RH 




06C9: 


C6 


02 


0K2 


DEC 


RL 




06CB: 


A0 


01 




LDY 


••01 


; «ove the two byte* 


08CD: 


Bl 


00 




LDA 


(S> , Y 


; at S to the 


08CF: 


91 


02 




STA 


<R> , Y 


I two byte* at R 


08D1 : 


ee 






DEY 






0802: 


Bl 


00 




LDA 


(SI , Y 




08D4: 


91 


02 




STA 


(R> , Y 




06D6: 


E6 


00 




INC 


SL 


f incr eeent 5 by 2 


08 D8: 


D0 


02 




BNE 


0K3 




06 DA: 


E6 


01 




INC 


SH 




06 DC: 


E6 


00 


OK 3 


INC 


SL 




08 DE: 


D0 


02 




BNE 


OK4 




06E0: 


E6 


01 




INC 


SH 




08E2: 


60 




OK4 

•• R> •* 


RTS 






06E3: 


02 


D2 BE 


A0 B5 08 








06E9: 


E6 


00 




INC 


SL 


t decrement S by 2 


08EB: 


C6 


00 




DEC 


SL 




06ED: 


D0 


02 




BNE 


OKI 




06EF: 


C6 


01 




DEC 


SH 




06F1: 


C6 


00 


OKI 


DEC 


SL 




06F3: 


D0 


02 




BNE 


OK2 




•6F5: 


C6 


01 




DEC 


SH 




•6F7: 


C6 


00 


OK2 


DEC 


SL 




06F9: 


A0 


01 




LDY 


••01 


; aovt the two byte* 


08FB: 


Bl 


02 




LDA 


(R) , Y 


( at R to the 


06FD: 


91 


00 




STA 


(S) , Y 


; two bytes at S 


•6FF: 


B8 






DEY 






0900: 


Bl 


02 




LDA 


(R> , Y 




0902: 


91 


00 




STA 


<S) , Y 




0904: 


E6 


02 




INC 


RL 


t increment R by 2 


09«6: 


D0 


02 




BNE 


OK3 




0906: 


E6 


03 




INC 


RH 




090A: 


£6 


02 


OK 3 


INC 


RL 




0^0C: 


D0 


02 




BNE 


OK4 




090E: 


E6 


03 




INC 


RH 




0910: 


60 




OK4 

• 


RTS 






091 1 : 


01 


C9 A0 


* 

A0 E3 08 








0917: 


£6 


00 




INC 


SL 


f drtrmnt S by 2 


0919: 


C6 


00 




DEC 


SL 




091B: 


D0 


02 




BNE 


OKI 




091D: 


C6 


01 




Dec 


SH 




091F: 


C6 


00 


OKI 


DEC 


SL 




•921 : 


D0 


02 




BNE 


OK2 




0923: 


C6 


01 




DEC 


SH 




0925: 


C6 


00 


OK2 


DEC 


SL 




0927: 


A0 


01 




LDY 


• •01 


f move the two bytes 


0929: 


Bl 


02 




LDA 


[R> , Y 


t at R to the 


092B: 


91 


00 




STA 


<S> , Y 


I two bytes at S 


092D: 


88 






DEY 






09 2E: 


Bl 


02 




LDA 


<R> , Y 




0930: 


91 


00 




STA 


IS> .Y 




0932: 


60 




•• 0E *• 


RTS 






•933: 


02 


B0 BD 


A0 1 1 09 








0939: 


A0 


00 




LDV 


• •00 


I are the two bytes 


093B: 


Bl 


00 




LDA 


<S> . Y 


t at S both jr-o' 1 


093D: 


D0 


06 




BNE 


NZ 




093F: 


CB 






INY 






0940: 


Bl 


00 




LDA 


(S) , Y 




•942: 


D0 


•3 




BNE 


NZ 




0944: 


96 






TYA 




; y*s, 41ag-«*001 

continued 
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•945: M 02 

0947: A9 00 

0947: A0 00 

094B: 91 00 

094D: 98 

094E: ca 

094F: 91 00 

0951: 60 



BNE ZERO 

LDA 0«00 

LDY ••00 

STA (S),V 

TYA 

I NY 

STA (S),Y 

RTS 



t no, 41ag-*0000 



0A1D: E6 00 

0*1 F: D0 02 

0A21: E6 01 

0A23: Efc 00 

•A23: D0 02 

0A27: E6 01 

0A29: 60 



INC 8L 

BNE OKI 
INC SH 
INC BL 
BNE 0X2 
INC SH 
RTS 



■2 CF 02 A* 04 «A 



0952: 02 B0 BC A0 33 09 

0958: A0 01 LDY »*01 

095A: Bl 00 LDA (St.Y 

•95C: 30 01 . Bfll MINUS 



I is tha MSB high? 



095f: 99 

0960: A0 i 

0962: 91 \ 

0964: 98 

0965: C8 

0966: 91 I 

0968: 60 



I no, flag* 

I yaa, *lag-»000l 



ETA 
TYA 
I NY 
STA 
RTS 



0969: 


01 


BD 


096F: 


A0 


00 


0971: 


Bl 


00 


0973: 


A0 


02 


0975: 


Dl 


00 


0977: 


D0 


0D 


0979: 


86 




097A: 


Bl 


00 


097C: 


A0 


03 


09 7E: 


Dl 


Be 


0960: 


D0 


0« 


09B2: 


A9 


01 


0984: 


00 


01 


0966: 


A9 


00 


0986: 


A0 


02 


098A: 


91 


00 


098C: 


C8 




098 D: 


A9 


00 


09BF: 


91 


00 


0991: 


E6 


00 


0993: 


D0 


02 


0995 = 


E6 


01 


0997: 


E6 


00 


0999: 


D0 


02 


099B: 


E6 


01 


099D: 


60 





A0 A0 52 09 



LDY 


••00 


LDA 


(S) ,Y 


LDY 


••02 


CMP 


(S) , Y 


BNE 


NEQ 


DFY 




LDA 


(S> , Y 


LDY 


• •03 


cup 


(St , Y 


BNF 


NEC 


LDA 


• •01 


BNE 


EC 


LDA 


••00 


LDY 


••02 


STA 


(St , Y 


I NY 




LDA 


• •00 


STA 


(St ,Y 


INC 


SL 


BNE 


OKI 


INC 


SH 


INC 


SL 


BNE 


OK2 


INC 


SH 


RTS 





I *-m tha too bytas 
; at S equal to the 
I two bytas at S+2"> 



t yas, <lag«**001 
t no, 4 1ag-*0000 



0A2A: 

•A30: A0 00 

•A32: Bl 00 

•A341 A0 02 

0A36: 11 00 

•A38: 91 00 

0A3A: ee 

0A3B: Bl 00 
0A3D: A*) 03 

0A3F : 1 1 00 
0A41: 91 00 
0A43: E6 00 
0A4S: D0 02 
0A47: E6 01 
0A49: £6 00 
0A4B: D0 02 
0A4D: E6 01 
•A4F: 60 



LDY 0*00 

LDA (S),Y 
LDY 0*02 

ORA (S),V 
STA (S),Y 
DEY 

LDA <6>,Y 
LDY 0*03 
ORA (S),Y 
STA (S),¥ 
INC SL 
BNE OKI 
INC SH 
INC SL 
BNE OK2 
INC SH 
RTS 



OR that two bytas 

■tarttng at S 

with that two at 5*2 



I incr M int S by 2 



•• I OR • • 



099E 


01 


BC 


09A4 


A0 


02 


09A6 


38 




09A7 


Bl 


00 


09A9 


A0 


06 


09AB 


Fl 


00 


09AD 


A0 


03 


09 AF 


Bl 


00 


09B1 


A0 


01 


09B3 


Fl 


00 


09B5 


50 


02 


09B7 


49 


8tf 


09B9 


29 


60 


09BB 


0A 




09 BC 


2A 




09BD 


CB 




09 BE 


91 


00 


09C0 


A9 


00 


09C2 


C8 




09C3 


91 


00 


09C5 


E6 


00 


09C7 


D0 


02 


09C9 


£6 


01 


09CB 


Efc 


00 


09CD 


D0 


02 


09CF 


E6 


01 



A0 A0 69 09 



0A50: 


03 


D6 CF 


D2 2A 0A 








0A56: 


A0 


00 




LDY 


••00 


t XOR tha two bytas 


0AS8: 


Bl 


00 




LDA 


IS) ,Y 


; starting at S with 


0A5A: 


A0 


02 




LDY 


■•02 


; tha two at 5+2 


0A5C: 


51 


00 




EOR 


<S) , Y 




0A5E: 


91 


00 




STA 


(St ,Y 




0A60: 


88 






DEY 






0A6K 


Bl 


00 




LDA 


<S),Y 




0A63: 


A0 


03 




LDY 


••03 




0A65: 


51 


00 




EOR 


<5> , Y 




0A67: 


91 


00 




STA 


(St ,Y 




0A69: 


E6 


00 




INC 


SL 


I incrawant S by 2 


0A6B: 


D0 


02 




BNE 


OKI 




0A6D: 


E6 


01 




INC 


SH 




0A6F: 


E6 


0« 


OKI 


INC 


SL 




0A71 : 


D» 


02 




BNE 


0K2 




0A73: 


E6 


01 




INC 


SH 




0A75: 


60 




OK2 


RTS 







•• NOT •• 



49 FF 



LDY 


••02 


; coapiri tha two bytas 


SEC 




t at S*2 with tha 


LDA 


(St , Y 


i two bytas at 5 


LDY 


• •00 




SBC 


(St, Y 




LDY 


• •03 




LDA 


(S) ,Y 




LDY 


••01 




SBC 


(S) ,Y 




BVC 


0* 1 




EOR 


••80 




AND 


•*e# 




ASL 






ROL 




i and product a 4 1 ag 


INY 






STA 


<S) ,Y 




LDA 


•*0 




INY 






STA 


<S),Y 




INC 


SL 


i incrawant S by 2 


BNE 


OK2 




INC 


SH 




INC 


SL 




BNE 


0K3 




INC 


SH 




RTS 







0A76: 
0A7C: 
0A7E: 
0A80! 
0A82: 91 00 
0A84: 88 
0A85: Bl 00 
0A87: 49 FF 
0A89: 91 0« 



03 CE CF D4 50 0A 



LDY •*0I 

LDA (St,Y 

EOR *«FF 

STA (Sl.Y 
DEY 

LDA (SJ.Y 

EOR «*FF 

STA (S>,Y 



01 AB A0 A0 76 0A 



0ABC 

0A92: 16 

0A93: A0 00 

0A95: Bl 00 

0A9 7: A0 02 

0A99: 71 00 

0A9B: 91 00 

0A9D: 88 

0A9E: Bl 00 

0AA0: A0 03 

0AA2: 71 00 

0AA4: 91 00 

0AA6: E6 00 

0AA8: D0 02 

0AAA: D0 02 

0AAC: E6 00 

0AAE: D0 02 

0AB0: E6 01 

0AB2: 60 



CLC 

LDY ••00 

LDA (St,Y 
LDY «S02 
ADC (S),Y 
STA (S>,Y 
DEY 

LDA <S),Y 
LDY tt«03 
ADC (St.Y 
STA (Sl.Y 
INC SL 
BNE OKI 
INC SH 
INC SL 
BNE OK2 
INC SH 
RTS 



t taka tha 

1 o* tha t 
i starting 



add tha 
starting 
tha two 



09D2: 01 BE A0 A0 9E 09 
09D8: A0 00 



09DA: 


38 






SEC 




E at S with tha two 


09 DB: 


Bl 


00 




LDA 


(5) , Y 


; bytas at S+2 


09DD: 


A0 


02 




LDY 


••02 




•9DF: 


Fl 


00 




SBC 


<S> ,Y 




•9E1: 


ee 






DEY 






•9E2: 


Bl 


00 




LDA 


(S) ,V 




•9E4: 


A0 


03 




LDY 


• •03 




09E6: 


Fl 


00 




BBC 


(S) , Y 




•9EB: 


50 


02 




BVC 


OKI 




•9EA: 


49 


80 




EOR 


••80 




09EC: 


29 


60 


OKI 


AND 


••80 




•9EE: 


0A 






ASL 






•9EF: 


A9 


00 




LDA 


•«00 




•9F1: 


91 


00 




STA 


(SI , Y 




•9F3: 


Bfi 






DEY 






•9F4: 


2A 






ROL 






•9F5: 


91 


00 




STA 


(5) , Y 




•9F7: 


E6 


00 




INC 


SL 


1 incrawant S by 2 


•9F9: 


DB 


02 




BNE 


0K2 




•9FB: 


E6 


01 




INC 


SH 




•9FD: 


E6 


00 


0K2 


INC 


SL 




09FF: 


00 


02 




BNE 


0K3 




0A0i: 


E6 


01 




INC 


SH 




0A03: 
0A#4: 


60 
03 


CI CE 


0X3 

<Ht AND •* 

* 

C4 D2 09 


RTS 






•AtfA: 


A0 


00 




LDY 


0*00 


1 AMD tha two bytas 


0A0C: 


Bl 


00 




LDA 


IS) ,Y 


1 starting at S with 


BABE: 


A0 


02 




LOY 


0*02 


| tha two at S+2 


BA10: 


31 


00 




AND 


<S> , Y 




•A12: 


91 


00 




STA 


(St ,Y 




•A14: 


se 






DEY 






•A15: 


Bl 


00 




LDA 


(SI ,Y 




0A17: 


AB 


B3 




LDY 


••03 




•A19: 


31 


00 




AND 


(S> ,Y 




•A1B: 


91 


00 




BTA 


IB) , Y 





0AB3 

0AB9: 38 

•ABA: A0 02 

•ABC: Bl 00 

•ABE: A0 00 

0AC0: Fl 00 

0AC2: A0 02 

0AC4: 91 00 

0AC6: CB 

0AC7: Bl 00 

0AC9: A0 01 

•ACB: Fl 00 

•ACD: A0 03 

•ACF: 91 00 

•ADU E6 00 

•AD3: D0 02 

•AD5: E6 01 

0AD7: £6 00 

•AD9: D0 02 

•ADB: £6 01 

•ADD: 60 



01 AD A0 A0 BC 0A 



SEC 

LDY ••02 

LDA (St.Y 

LDY «S00 

SBC (St.Y 

LDY ••02 

STA (S),Y 
INY 

LDA (St.Y 

LDY ••01 

SBC (Sl.Y 

LDY «S03 

STA (S!,Y 

INC SL 

BNE OKI 

INC SH 

INC SL 

BNE 0K2 

INC SH 
RTS 



•• NEGATE •• 



I subtract tha two bytas 
I starting at S frow 
i tha two at S+2 



•ADC: 


06 


CE 


C5 


C7 


B3 0A 








0AE4: 


20 


7C 


0A 






JSR 


NOT 


I first taka tha com 


0AE7: 


A0 


00 








LDY 


••00 


t than incrawant tha 


0A£9: 


Bl 


00 








LDA 


(S) ,Y 


f two bytas starting 


0AEB: 


IB 










CLC 






•AEC: 


69 


01 








ADC 


••01 




•ACE: 


91 


00 








STA 


(S) ,Y 




•AF0: 


90 


07 








BCC 


DONE 




•AF2: 


CB 










INY 






•AF3: 


Bl 


00 








LDA 


(Sl.Y 




0AFS: 


69 


00 








ADC 


••00 




0AF7: 


91 


00 








STA 


<S> , Y 




0AF9: 


60 






DONE 


RTS 
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** ABS •• 

0AFA: 03 CI C2 D3 DC 0A 

•B00: A0 01 LDV ««01 

0B02: Bl 00 LDA (S) ,Y 

0B04: 19 »3 BPL DONE 

•B06: 4C E4 *A JMP NEGATE 

WbvV: <* DONE RTS 

•• 16*16-32 •• 



0B0A 


A9 


00 




•B0C 


85 


12 




0B0E 


85 


13 




0B10 


65 


14 




0B12 


85 


15 




0B14 


85 


16 




0B16 


85 


17 




•BIB 


46 


•F 


PASS 


0B1A 


66 


0E 




•B1C 


90 


19 




• B1E 


ie 






0B1F 


AS 


10 




0B21 


65 


14 




0B23 


85 


14 




0B25 


A5 


11 




•B27 


65 


15 




0B29 


85 


15 




0B2B 


A5 


12 




•B2D 


65 


16 




0B2T 


85 


16 




0t>31 


A5 


13 




•B33 


65 


17 




0B35 


85 


I"> 




0B37 


06 


10 


SHIFT 


0B39 


26 


1 1 




0B3B 


26 


12 




063D 


26 


13 




0B3F 


A5 


0E 




•B41 


D0 


D5 




0B43 


A5 


0f 




0B45 


D0 


Dl 




•B47 


60 







LDA «»00 


cli«r 


BTA ACCB2L 




STA ACC.B2H 




STA ACC.CIL 




STA ACC.C1H 




STA ACC.C2L 




STA ACC.C2M 




LSR ACC.AM 


check 


ROR ACC.AL 




BCC SHIFT 


bf «nc 


CLC 


add i 


LDA ACC.BIL 


B*C - 


ADC ACC.C1L 




STA ACC.CIL 




LDA ACC. BIH 




ADC ACC.C1H 




STA ACC.C1H 




LDA ACC. B2L 




ADC ACC.C2L 




STA ACC.C2L 




LDA ACC.B2H 




ADC ACC.C2H 




STA ACC.C2H 




ASl ACC . B 1 L 


and » 


ROL ACC. BIH 




ROL ACC.B2L 




ROL ACC.B2H 




LDA ACC.AL 


unti 1 


BNE PA55 




LDA ACC. AH 




BNE PASS 




RTS 





is the MSB high-> 



accumulators 



i + not sat 



shift B le-ft 



•BC0: 85 0F 

•BC2: 88 

•BC3: Bl 00 

•BC5: 85 0E 

0BC7: 20 09 I 

•BCA: 20 00 I 

•BCD: A0 01 

0BCF: Bl 00 

•BD 1 : 85 1 1 

•BD3: 88 

•BD4: Bl 00 

0BD6: 85 10 

0BD6: 60 



STA 


ACC. AH 




DEY 






LDA 


(S> ,Y 




STA 


ACC.AL 




JSR 


DROP 




JSP 


ABS 


and that o-* 


LDV 


••01 


tha ucond 


LDA 


*S) , Y 




STA 


ACC. BIH 




DEY 






LDA 


<S> , Y 




STA 


ACC.BIL 




RTS 







•• ACC-> •* 



No Header 



•BD9: 


A0 


•0 








LDY 


••00 1 


put bac* 


•bdb: 


A5 


14 








LDA 


ACC.C1L i 


th* rvtii 


•BDD: 


91 


00 








STA 


<S> ,Y 




0BDF: 


ce 










I NY 






•BE0: 


AS 


15 








LDA 


ACC . C 1 H 




•BE2: 


91 


00 








STA 


<S) , Y 




0BE4: 


A5 


IB 








LDA 


SCRL ; 


with tha 


•BE 6: 


10 


03 








BPL 


DONE 1 


prop** - s 


0BEB: 


4C 


E4 


•A 






JMP 


NEGATE 




0BEB: 


60 






DONE 


RTS 






•BEC; 


01 


AA 


A0 


A0 


FA 0A 








0BF2: 


20 


AF 


0B 






JSR 


->ACC 




•BF5: 


20 


61 


0B 






JSP 


16* 16- 16 




•BFB: 


4C 


D9 


0B 






JMP 


ACC-> 





01 AF A0 A0 EC 0B 

20 AF 0B 



0BFB 
0C01 

0C04: A9 00 

0C06: 85 12 

0C08: 85 13 

0C0A: 20 48 0B 

•C0D: 4C D9 0B 



JSR ->ACC 
LDA • •00 i 

STA ACC.B2L f 
5TA ACC.B2H 
JSR 32/16=16 
JMP ACC-> 



** 32/16=16 *• 



No Header 



0C10: 04 AF CD CF FB 08 
0C16: A0 03 



•846: 


A9 


00 




LDA 


• •00 


0B4A: 


85 


14 




STA 


ACC.C1L 


0B4C: 


85 


15 




STA 


ACC.C1H 


•B4E: 


A2 


10 




LDX 


• «10 


•B50: 


06 


10 


PAS 5 


ASL 


ACC . B I L 


0B52: 


26 


1 1 




ROL 


ACC .BIH 


0B54: 


26 


12 




ROL 


ACC.B2L 


0B56: 


26 


13 




ROL 


ACC . B2H 


•B58: 


90 


0C 




BCC 


NORMAL 


•B5A: 


A5 


12 




LDA 


ACC. B2L 


•B5C: 


E5 


0E 




SBC 


ACC.AL 


•B5£: 


4B 






PMA 




•B5f : 


A5 


13 




LDA 


ACC.B2H 


•B6i: 


E5 


0F 




SBC 


ACC. AH 


0B5A: 


AS 


12 




LDA 


ACL . B2L. 


0B5C: 


E5 


0E 




SBC. 


ACC . At 


0B5E: 


4B 






PHC 




•BSF: 


A5 


13 




LDA 


ACC. BTH 


0B6l : 


E5 


0f 




SBC 


ACC. AH 


0B63: 


38 






DFC 




0B64: 


B0 


0C 




BCS 


SUE- 


0B66: 


3B 




NOftHAI 


SEC 




0B67: 


AS 


12 




LDA 


ACC. B?L 


di 4 + arance 








•B69: 


E5 


0£ 




SBC 


ACC. AL 


086 B: 


46 






PHA 




•B6C: 


A5 


13 




LDA 


ACC. B2H 


•B6E: 


E5 


0F 




SBC 


ACC. AH 


0B70: 


90 


02 




BCC 


NOSUhl 


0B7?: 


BS 


13 


SUP 


STfl 


ACC. 6?H 


0B74: 


66 




NOSiJB 1 


PL A 




0B75: 


90 


02 




BCC 


NOSUB2 


0B77: 


85 


12 




STA 


ACC. B7L 


0B79: 


26 


14 


nosub? 


ROL 


ACC.C1L 


0B7B: 


26 


15 




ROL 


ACC . C 1 H 


0B7D: 


CA 






DE* 




0B7E: 


D0 


D0 




BNf 


PASS 


0B80: 


60 






RTS 





•B83: 


85 


14 


0B85: 


BS 


15 


0B87: 


46 


0f 


0B89: 


66 


0t 


0B8B: 


90 


0D 


OB8D: 


IB 




•BSE: 


-*5 


10 


•890. 


65 


14 


0B92: 


BS 


14 


•B94: 


A5 


1 1 


•B96: 


65 


15 


0B98: 


85 


15 


0B9A: 


06 


10 


0B9C: 


26 


1 1 


0B9E: 


A5 


0E 


0BA0: 


D0 


04 


0BA2: 


A5 


0F 


0BA4: 


F0 


08 


0BA6: 


A5 


1 1 


0BA8: 


D0 


DD 


•BAA: 


A5 


10 


•BAC: 


D0 


D9 


0BAE: 


60 





; have we 



ssed a 
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BCC NOADD 
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LDA ACC. BIL 

ADC ACC.C1L 

STA ACC.C1L 

LDA ACC. BIH 

ADC ACC.C1H 

STA ACC.C1H 

ASL ACC.BIL 

ROL ACC. BIH 

LDA ACC.AL 

BNE NOPE 

LDA ACC. AH 

BED DONE 

LDA ACC. BIH 

BNE PASS 

LDA ACC. BIL 

BNE PASS 
RTS 
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LDA (S) , Y ; unsigned n 

STA ACC.AL. Y 

DEY 

BPL LOOP 

INY ; claar out 

STY ACC.B2L J rest oi B 

STY ACC.B2H 

JSR 32/16=16 

INC SL ; drop a val 

BNE OKI 

INC SH 

INC 5L 

BNE LX2 

INC SH 

LDY «»00 J and return 

LDA ACC.B2L ! tha ra*»ir 

STA (S>,Y 
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LDA ACC.B2H 
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JSR DROP ; first multiply 

JSR - >ACC ; the tirst two 

JSR 16*16=32 ; nuaoars 
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STA SL 
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EOR SCRL 

STA SCRL 
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Which. . 
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YOU buy? 



Global Specialties 
QT-59S Socket 

• 590 Tie Points 

• 8-1. C Capacity 

• No Grid Labeling 

• Horizontal Expansion only 

• Screw-Down Mounting A 




If you have two similar products, both 
designed for the same function... and 
one offers you MORE features for LESS 
money... which would YOU buy? The 
answer is obvious 1 

Just look at all these EXTRAS built into 
every HANDY test socket and buss strip... 

• Total contact labeling... 

simplifies circuit design/layout 

• Self-adhesive backing... for one-step 
simplified alignment and mounting 

• Full 9 14-Pln I.C. Capacity 

• Expands both horizontally and 
vertically. ..interlocks can't break 
or twist off 

• High temperature plastic housing... 

to 80° C ... no warping or melting ever! 

• Prices always up to 25% less than 
other leading brands 

To all these add: Long Life, low resistance 
and wide range contacts that accept 
combinations of resistors, capacitors, 
diodes, transistors, I.C.s, etc. with leads 
from .012 - .032" or 20 - 29 AWG. Clear, 
easy-to-read-and-identify contact mark- 
ings simplify layout, wiring and docu- 
mentation. Socket rows are labeled 1-to- 
64. and columns are marked A-to-E and 
F-to-J. Mating buss strip rows are labeled 



A-to-D and consist of 25 contacts each 
Bold red and blue lines show where 
contact strips begin and end. 

Finally, we have a full line of breadboard- 
ing equipment, from discrete sockets and 
buss strips to multi-board assemblies, 
available at comparable lower-than-low 
prices. 



Let's face it. If you get all this . . . and 
the prices are ALWAYS to 25% less. . . 
there's no doubt which you'll buy. 
HANDY. It's our name. ..and it tells you 
what we do. 

What are you waiting for? Order your 
HANDY breadboarding products today. 
A toll-free call is all it takes! 



Here's how to order. . . 
HANDY Sockets and Buss Strips 


Part Socket Buss 
Number Strips Strips 


Ground 
Plate 


Tie 
Points 


14 pin 
ICCapty. 


Price 


HB-0100 N/A 1 
HB-1000 1 N/A 
HB-1110 1 1 
HB-1210 1 2 


no 

no 

yes 

yes 


100 
640 
740 
840 


N/A 
9 
9 
9 


2.25 

995 

11.95 

13.95 


HANDY Breadboard Assemblies 


Part Socket Buss 
Number Strips Strips 


Binding 
Posts 


Tie 
Points 


14 pin 
IC Capty. 


Price 


HB-2112 2 1 
HB-2313 2 3 
HB-3514 3 5 
HB-4714 4 7 


2 

3 
4 
4 


1380 
1980 
2420 
3260 


18 
18 
27 
36 


25.95 
31.00 
47.95 
63 95 



Mall Ordtri: Please add S3 (Canada A mil add $5) to cover cost ol shipping/handling 

Charge Carda: (Mm $15) Please include Acct No . Exp Date. Bank No (M/C only) and your signature 

Checks: Drawn in U S Dollars on US banks only Connecticut Reeldents: Add 7»% Sales Tax 



Sorry! No C O.D orders 



G3£| 






order.call 1-800-34-HANDY 

charge with VISA, MasterCard or American 
items off-the-shelf for Immediate Shipment! 



Express.! 



a division of RSP Electronics Corp. 

7 Business Park Drive • P.O. Box 699 • Branford, CT 06405 • (203) 488-6603 • TWX: (910) 997-0684 

Easy Link Mail Box: 62537580 • CompuServe: 71346, 1070 

U.S. and Canadian Distributor inquiries welcomed. 
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Interfacing Tips and Troubles 

A Column by Neil Bungard 



Introduction 

Every new column begins with a particular theme in 
mind. Perhaps an appropriate theme for "Interfacing Tips 
' and Troubles" would be "get down to brass tacks and make 
the interface work." This column will take a practical and 
workable approach to connecting computers to the real 
world. We will look at the troubles which you will likely 
encounter when attempting to connect interface circuits to 
your computer, and we will review some handy tips which 
will make your interfacing tasks a little less work. As you 
may have already discovered, conceptualizing a circuit, 
creating a logic diagram, and wiring the circuit are only part 
of an interfacing task. Once all of these things have been 
done, you've still got to make the interface work. Sometimes 
you can connect your interface to the computer and it works 
the first time, but in many cases it does not. You may trace 
your circuit and find that it has been wired correctly, so you 
go back to the schematic diagram to see if you've made a 
logic error. Upon discovering that your logic was correct 
you disconnect the interface from the computer, connect 
wires to the buses and the control signal inputs of your 
circuit, and check the interface under static conditions. 
Surprisingly, it works! Where to next? That's part of what 
this column is all about — determining the source of 
problems which don't appear on the logic diagrams. Such 
problems can be caused by power supply noise, lack of 
sufficient (or proper) decoupling, improper cable 
termination, mismatched transfer timing, and a number of 
other conditions which are rarely discussed in interfacing 
literature. I will address a number of these issues myself 
and I hope to solicit help from you, the readers, who have 
encountered and solved such problems in your interfacing 
experiences. 

Although the interfacing techniques are straightforward, 
each personal computer has its own unique idiosyncrasies 
which may add a "twist" to the interfacing process. As you 
interface your computer and discover its particular quirks, 
drop us a letter; we would like to share the benefits of your 
experience with others who own similar machines. 

"Interfacing Tips and Troubles" also hopes to provide a 
number of helpful tips that will assist you in your 
interfacing tasks. These "tips" will range from software 
suggestions to trick circuits which will hopefully help you as 
you connect your computer to the real world. Here again, 
your experience can be of benefit to us. Everybody has a 
trick which has made interfacing a little easier for you. Drop 
us a line; we would like to share your trick with others. 

DC to DC Converter 

We will begin this column with a handy little circuit which 



eliminates the need for multiple output power supplies in 
applications where the supply current requirements are low. 
Some of the applications for such a circuit include: voltage 
levels for the RS 232 serial interface, programming voltages 
for EPROMs and CPUs, voltage references for analog to 
digital converters, etc. Typically, if a circuit requires more 
than one voltage, a multiple output power supply is used. A 
few disadvantages of the multiple output power supply are 
that it is physically large, relatively expensive, and in many 
cases is hard to find for the specific voltages that you are 
interested in. Another problem is adding ICs that require 
voltages other than five volts to a circuit with only a five 
volt power supply. At this point, if you are going to use a 
multiple output power supply, you must replace the existing 
supply. Of course, you would like to avoid that if possible. 

I have managed to avoid multiple output power supplies 
in many applications by using a little circuit shown to me by 
Cam "Cannonball" Reid. Cam is always good for a trick 
circuit when I need one. This circuit is a DC to DC converter 
that you can build and place right on the board to generate 
needed voltage levels. A general circuit diagram of the DC 
to DC converter is shown in Figure 1. NPN transistors Ql 






Figure 1: General DC to DC Converter. 



and Q2, resistors Rl and R2, and the primary of transformer 
Tl form an astable multivibrator. The frequency of the 
multivibrator is somewhat dependent upon the physical 
characteristics of Tl, but in general it will oscillate at about 
lOOOhz. As the multivibrator oscillates, it induces a voltage 
into the secondary of Tl. The voltage in the secondary 
winding is stepped up according to the relationship: 



v s = 



_NS_ 

N P 



xV P 



V s « Voltage Secondary 
V p - Voltage Primary 
N s - Turns Secondary 
N p = Turns Primary 
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A bridge rectifier converts the secondary oscillation to an 
unfiltered direct current and capacitor CI smooths the 
waveform. Since the frequency of the unfiltered DC is 
relatively high (compared to 120hz for a conventional power 
supply), capacitor CI can be small (about lOOmf). As shown 
in the photograph in Figure 2, the DC to DC converter can 
be made very small so that little board space will be 
dedicated to accomplishing your voltage conversion. 

This DC to DC con- 
verter can be used to 
generate either a 
positive or a negative 
voltage by simply 
connecting the ap- 
propriate leg of the 
bridge rectifier to 
ground. Development 
of the DC to DC con- 
verter can be carried 
further to incorporate 
a three terminal volt- 
age regulator (like the 
7905) to ensure a stable voltage level. A plus and minus 
output is also possible from the DC to DC converter. 
By center tapping the secondary winding and connecting the 
center tap to ground, a positive voltage can be obtained 
from one leg of the bridge rectifier and a negative voltage 
can be obtained from the other leg. Circuits representing 
these applications will be presented in the following 
discussions. 

The following circuits represent a couple of applications 
for which I have personally found the DC to DC converter 
useful. In the first circuit (Figure 3), the DC to DC converter 
was used to generate the programming voltage for a 2716 
EPROM. It was very important that the programming 
voltage did not exceed 25 volts, so the output of the supply 
was regulated with a zener diode. The circuit in Figure 3 
works exactly like the general DC to DC converter circuit in 
Figure 1. Tl, a toroidal core transformer, can be purchased 
from Mouser Electronics for about a dollar, and they can be 
ordered in various sizes. The size (in inches) used in the 
converter above was: 0.50 (outside diameter) by 0.30 (inside 
diameter) by 0.19 (height). The primary winding consists of 
about 20 turns of number 26 enameled copper wire. The 
number of turns on the secondary winding was calculated 
according to the equation: 



N s = 



xN, 



These windings were then placed on the core and Tl was 
wired into the converter circuit. The converter circuit was 
to be regulated at 25 volts under a loaded condition so that 
the unregulated voltage was adjusted to about 26.5 volts. To 
adjust the unregulated output, remove the zener diode from 
the circuit, place a voltmeter on the secondary of Tl until 
the desired voltage is obtained. Once the 26.5 volts is 
obtained, place the zener diode back into the circuit — the 
DC to DC converter is now ready for service. 




The circuit in Figure 4 is an example of generating a 
negative 12 volt reference using the DC to DC converter 
and a standard three terminal voltage regulator (7912). 
Before adjusting the secondary voltage, consult the 
specifications for the particular regulator that you are using. 
These three terminal regulators require a minimum input to 
output voltage difference to operate properly. Also keep in 
mind that the voltage difference between the input and the 
output will be dropped across the voltage regulator and 
dissipated as heat, so stay as close to the minimum 
difference specification as possible. The capacitors, C2 and 
C3, on either side of the voltage regulator in Figure 4 
ensure that oscillations do not occur within the voltage 
regulator itself. 
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Figure 4: DC to DC Converter with - 12V Regulated Output. 



My favorite application for the DC to DC converter circuit 
is shown in Figure 5. This circuit configuration generates 
the plus and minus voltages required for an RS 232 serial 
interface. As you can see, the secondary is center tapped. 
With the center tap grounded, a negative voltage is 
obtained from one leg of the bridge rectifier and a positive 
voltage is obtained from the other. The RS 232 voltage 
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Figure 5: DC to DC Converter with ± 12V Outputs. 
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Multi-user 

A Column by E.G. Brooner 



IrV hile talking about networks and other multi-user 
systems, we should keep in mind that most of the concepts 
originated with large mainframe or minicomputer 
companies, and are just now being adapted to micros. This is 
for the same reason that micros themselves are popular, 
namely that they are more cost effective in the instances 
where they are adequate — as they indeed are for a great 
many applications. 

As one of the pioneer microcomputer makers, Cromemco 
is in a position to take advantage of the current multi-user 
boom -they have done this with C-NET. C-NET is a true 
network, and exhibits most of the finer features that 
distinguish such systems from lesser lookalikes. 

This system features a relatively high-speed data rate of 
0.5 megabytes per second, true collision detection, and 
packet message construction. It uses the "bus" topology (in 
which all stations are effectively in parallel across a common 
transmission medium) and permits up to 255 users to be 
connected at any one time. It generally follows the OSI 7- 
level protocol system; the three lower, or network levels are 
hardware on a plug-in S-100 board and the transport 
(routing, etc.) is handled by associated software. Levels five, 
six, and seven of the OSI model are necessarily machine- 
dependent in any network operation and are not considered 
a function of the network itself. 

Figure 1 is a photo (courtesy Cromemco) of their plug-in 
network board, which is most of what you need to adapt a 
Cromemco computer for network use. This is a standard S- 
100 (IEEE-696) board and although it was designed with 
their computers in mind, there is no fundamental reason it 
could not be used in any other S-100 bus computer. Figure 2 
is Cromemco's illustration of a typical C-NET configuration. 




Figure 1 



The functions they depict here are perhaps atypical of the 
installation that would be made by most small users; one of 
the interesting features they show is a gateway to a distant 
point. We have not previously discussed gateways in this 
column. 

Earlier discussions described LANs as being very local in 
nature and confined, generally, to a building or relatively 
small complex. These limitations are imposed by the high 
speed at which networks usually operate. Long-distance 
communication is inherently at a slower rate. A gateway is a 
means of connecting a network, or some of its users, to a 
distant point. It may also connect two similar networks 
which, for some reason, cannot be totally combined. 
Communication with the distant point does not take place at 
high network speeds. The medium associated with a 
gateway may be telephone, satellite, or any other means of 
connecting two digital devices. Essentially, the gateway is 
an external connection, at which translations of speed and/or 
protocol may have to take place. 

To understand gateways, we will have to discuss network 
protocols in a little more detail than we have in previous 
columns. 

The International Standards Organization (ISO) has 
developed a plan known as the OSI, or Open Systems 
Interconnection model. This plan attempts to define all 
interactions between digital equipment, and between 
equipment and applications, as seven families of standards 
and protocols. The term "7-level protocols" is often used to 
describe this scheme. The RS-232 standard, the Centronics 
parallel standard, and the IEEE-488 bus are all level one 
protocols when viewed in this context — in other words, they 
are means of connecting equipment at the lowest level. 

All methods of formatting data for transmission, such as 
SDLC, HDLC, and the various "packet" configurations, are 
level two protocols. It is important to note that the OSI 
model does not attempt to standardize any single protocol at 
any level, but only defines the functions that will be 
performed. 

Needless to say, manufacturers do not always (as yet) 
follow this scheme. Ethernet, as an example, lumps levels 
one and two together and calls it "Ethernet;" this poses no 
problems unless one would try to interface something into 
an Ethernet between levels one and two. IBM and other 
mainframe makers usually have some kind of "network 
architecture" (such as IBM's SNA) that combine all of the 
low-level protocols in an inseparable manner. 

Using the OSI concept, each level provides a transition to 
the next higher and next lower layers. It is apparent that if 
one network uses a certain type of level three or network 
control protocol, and another uses a different protocol for 
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the same purpose, they are not compatible. 

Finally, we get back to the concept of a "gateway." If at 
any point in a communication system it is necessary to 
translate from one protocol to another, at an equal level, a 
gateway is necessary. The gateway might change a format, 
a code, the speed of transmission, or the type of medium 
that is being used. 

Cromemco does not advertise the details of the gateway 
shown in their functional diagram and, in fact, they may 



have several different configurations for different purposes. 
Now that we are on the subject of the protocol model, we 
should go ahead and define the rest of them as well as the 
state of the art permits. As explained earlier, level one is 
the direct connection of equipment, level two is the format 
of the transmission, and level three is the network control. 
There is no general agreement on the distinction between 
three and four -both are concerned with "transporting" 
data between points after it is continued on page 22 
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Searching for Useful Information? 

The Computer Journal is for those who interface, build, and apply micros. No 
other magazine gives you the fact filled, how-to, technical articles that you need to 
use micros for real world applications. Here is a list of recent articles. 



Volume 1, Number 1: 

• The RS-232-C Serial Interface, Part One 

• Telecorrup^ng Wltyi the Apple][: Transferring 
Binar^([)V Q 

• Begmner's Column, Part One: Getting Started 

• Build an "Epram" 

Volume 1, Number 2: 

• File Transfer Programs for CP/M 

• The RS-232-C Serial Interface, Part Two 

• Build a Hardware Print Spooler, Part One: 
Background and Design 

• A Review of Floppy Disk Formats 

• Sending Morse Code With an Apple][ 

• Beginner's Column, Part Two: Basic Concepts 
and Formulas in Electronics 

Volume 1, Number 3: 

• Add an 8087 Math Chip to Your Dual Processor 
Board 

• Build an A/D Converter for the Apple][ 

• ASCII Reference Chart 

• Modems for Micros 

• The CP/M Operating System 

• Build a Hardware Print Spooler, Part Two: 
Construction 

Volume 1, Number 4: 

• Optoelectronics, Part One: Detecting, 
Generating, and Using Light in Electronics 

• Multi-user: An Introduction 

• Making the CP/M User Function More Useful 

• Build a Hardware Print Spooler, Part Three: 
Enhancements 

• Beginner's Column, Part Three: Power Supply 
Design 



Volume 2, Number 1: 

• Optoelectronics, Part Two: Practical 
Applications 

• Multi-user: Multi-Processor Systems 

• True RMS Measurements 

• GeminMOX: Modifications to Allow both Serial 
and Parallel Operation 

Volume 2, Number 2: 

• Build a High Resolution S-100 Graphics Board, 
Part One: Video Displays 

• System Integration, Part One: Selecting 
System Components 

• Optoelectronics, Part Three: Fiber Optics 

• Controlling DC Motors 

• Multi-User: Local Area Networks 

• DC Motor Applications 

Volume 2, Number 3: 

• Heuristic Search in Hi-Q 

• Build a High-Resolution S-100 Graphics Board, 
Part Two: Theory of Operation 

• Multi-user: Etherseries 

• System Integration, Part Two: Disk Controllers 
and CP/M 2.2 System Generation 

Volume 2, Number 4: 

• Build a VIC-20 EPROM Programmer 

• Multi-user: CP/Net 

• Build a High-Resolution S-100 Graphics Board, 
Part Three: Construction 

• System Integration, Part Three: CP/M 3.0 

• Linear Optimization with Micros 

• LSTTL Reference Chart 
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LEARN MICROCOMPUTER INTERFACING 
VISUALIZE SCIENCE PRINCIPLES 

Using GROUP TECHNOLOGY BREADBOARDS with your 
APPLE® ...COMMODORE 64® ...TRS-80® ...TIMEX-SINCLAIR® ...VIC-20® 

Versatile breadboards and clearly written texts with detailed experiments provide basic instruction in interfacing mi- 
crocomputers to external devices for control and information exchange. They can be used to provide vivid illustrations of 
science principles or to design interface circuits for specific applications. Fully buffered address, data, and control buses 
assure safe access to decoded addresses. Signals brought out to the breadboards let you see how microcomputer signals 
flow and how they can be used under BASIC program control to accomplish many useful tasks. 

Texts for these breadboards have been written by experienced scientists and instructors well-versed in conveying 
ideas clearly and simply. They proceed step-by-step from initial concepts to advanced constructions and are equally 
useful for classroom or individual instruction. No previous knowledge of electronics is assumed, but the ability to program 
in BASIC is important. 

The breadboards are available as kits or assembled. Experiment component packages include most of the parts 
needed to do the experiments in the books. Connecting cables and other accessory and design aids available make for 
additional convenience in applying the boards for classroom and circuit design objectives. Breadboard prices range from 
$34.95 to $350.00 
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The FD-ZX1 I/O board provides access to the Timex- 
Sinclair microcomputer for use in automated measure- 
ment, data acquisition, and instrument control applica- 
tions. A number of science experiments have been 
developed to aid teachers in illustrating scientific 
principles. The operating manual contains instructions for 
constructing input and output ports. A complete text of the 
experiments will be available later in 1984. The FD-ZX1 can 
be used with Models 1000, 1500, 2068, ZX81, and Spectrum. 



The INNOVATOR' BG-Boards designed by the pro- 
ducers of the highly acclaimed Blacksburg Series of books 
have gained wide acceptance for teaching microcomputer 
interfacing as well as for industrial and personal applica- 
tions. Detailed, step-by-step instructions guide the user 
from the construction of device address decoders and 
input/output ports to the generation of voltage and current 
signals for controlling servo motors and driving high- 
current, high-voltage loads. BG-Boards are available for the 
Apple II, II + , lie; Commodore 64 and VIC-20: TRS-80 Model 
1 with Level II BASIC and at least 4K read/write memory, 
Models III and 4. The books, Apple Interfacing (No. 21862) 
and TRS-80 Interfacing Books 1 and 2 (21633, 21739) are 
available separately. 

The Color Computer Expansion Connector Breadboard (not shown) for the TRS-80 Color Computer makes it possible 
to connect external devices to the expansion connector signals of the computer. Combined with a solderless bread- 
board and the book TRS-80 Color Computer Interfacing, With Experiments (No. 21893), it forms our Model CoCo-100 In- 
terface Breadboard providing basic interfacing instructions for this versatile computer. Experiments in the book show 
how to construct and use a peripheral interface adapter interface, how to input and output data,- and how digital-to-analog 
and analog-to-digital conversion is performed. 

Our new Spring Catalog describes the interface breadboards, dozens of books on microcomputer interfacing, pro- 
gramming, and related topics including the famous Blacksburg Continuing Education Series, a resource handbook for 
microcomputers in education, and a comprehensive guide to educational software; utility software for the TRS-80, 
scientific software for the Apple II, and other topics. We give special discounts to educational institutions and instructors. 
Write for the catalog today. 



Apple II. II-*-, and lie are registered 
trademarks ol Apple Computer Inc : 
Commodore 64 and VIC-20 are 
registered trademarks ol Commodore 
Business Machines; TRS-80 is a 
registered trademark of Radio Shack, 
a Tandy Corporation; Timex/Sinciair 
is a registered trademark of Timex 
Computer Corporation. 
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DOS WARS 

by Bill Kibler 



In the three-part series on integrating systems (Vol. II, 
nos. 2,3, and 4), I discussed operating systems in general. 
■Recently I was involved in a discussion at my computer 
club about the different types of operating systems and 
their merits. Many users, I am sure, still have 
some questions about which operating systems to use and 
why. It occurred to me that I should explain more about 
DOSs (disk operating systems) both for beginners and for 
those who work with them but sometimes forget what 
they're for. Understanding DOSs is becoming more 
important as a larger variety of systems is pushed by the 
manufacturers. 

DOS Designs 

Digitial Research Inc. made its name on the CP/M 
operating system. This system is the interface between the 
user and his computer. There are many different types of 
interfaces around. Some were even out before CP/M, but 
none provided such an open form of interface for 
independent writers of programs to use. Most interfaces 
before CP/M were company specific — that is, only software 
written by the company could run on their system. CP/M is 
an open standard which allows programs to move from 
system to system and is, for all practical purposes, 
independent of hardware considerations. This design opened 
up the microcomputer market and set the stage for the 
current DOS war. 

CP/M was designed around the Intel 8080 device. This 
means that the machine code which comprises the program 
will run only on the 8080. The Zilog Z80 is a superset of the 
8080 (contains the same machine instructions plus more 
special high speed functions) and will also run almost all 
CP/M programs unchanged. When used with an 8080 or Z80, 
CP/M is refered to as CP/M-80, as many newer versions of 
CP/M now exist. CP/M-86 is for the Intel 8086088, CP/M-68K 
for the Motorola 68000, CP/M-8K for Zilog's Z8000, and soon 
CP/M-16K for National's 16000 series of CPUs. All of these 
CPUs (central processing units) have 16 bit accumulators, 
whereas the 8080/Z80's is 8 bits. The other CPU 
enhancements concern the number of internal registers 
(temporary storage and pointers), the number of bits in each 
register, special register functions (indirect memory 
addressing), and how many address lines each can 
manipulate. Computers using the 16 bit CPUs can use more 
memory, perform larger calculations, and are supposed to be 
faster. 

Before IBM, microcomputers were considered by many to 
be just hobby items. Although a lot of people were doing 
very meaningful things with their computers, if IBM didn't 



do it, large business considered it a toy. When IBM entered 
the market, micros stopped being toys and many people 
bought their first computer (made by IBM). Due to financial 
considerations, IBM chose their operating system based on 
Microsoft's MSDOS. This program was originally written by 
Seattle Computers, and was adapted by Microsoft for the 
8086088 system. It has the same open interface (CP/M-like) 
that allows programs to run independently of hardware. 
With IBM behind the system, MSDOS is now becoming the 
16 bit standard, like it or not. 

The War Starts 

As one can probably guess, war between lovers of CP/M 
and MSDOS has been raging in many publications. The 
companies have countered with updated versions and even 
newer systems (concurrent CP/M). AT&T recently jumped 
into the fray with their UNIX operating system (originally 
for CPUs with a 32 bit design) and many 16 bit versions of 
it. The hour-long discussion at my computer club was on 
which one of these systems is best, and which one should be 
bought and learned. The general feeling was that none of 
the new systems merit buying now, but that they should be 
watched closely. This position is based on the current 
capabilities and prices of these products. 

In my articles on system integration I tried to stress the 
need for defining clearly in your mind why you are getting a 
computer. The same is true when dealing with operating 
systems. Choosing the wrong system will limit the number 
of off-the-shelf programs you can run. I use mostly public 
domain software and pay about $5.00 per 8" disk of 
programs. However, if I didn't use a CP/M system many of 
these programs would have cost me several hundred dollars 
per disk (my library has about 40 user group disks). There 
are currently several 16 bit programs in the normally 8 bit 
public domain, and separate MSDOS user groups are being 
formed (one group already has 135 IBM PCDOS disks). This 
wealth of programs has almost eliminated program 
availablity as a deciding factor in purchasing systems. 

In part three of System Integration, I tried to point out 
why I felt CP/M 3.0 was not necessarily a good buy. I still 
feel that users of a 2.2 system are better off installing a 
RAM DRIVE than upgrading to 3.0. This also holds for 
upgrading to MSDOS or CP/M-86 even if the hardware is 
cheap. My personal home computer is a new Heath Z-100, 
bought so that I would have access to all possible worlds (S- 
100 bus, CP/M-80, MSDOS, and CP/M-86). Since writing 
articles is 80% of its use, CP/M-80 gets used 80% of the 
time. This has also given me a chance to test system speeds, 
and again CP/M-80 wins. 
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System Design 

When the IBM PC first appeared in the trade journals, I 
studied the articles closely, and decided that it was a poorly 
designed machine. Since then, several articles have 
appeared showing how slow and cumbersome its design is. 
These facts have not stopped first time users from spending 
$4000 on the name. I would guess that many users are 
unaware of the system's poor features. Dedicated 2.2 users 
who use IBM usually become frustrated with its slow speed, 
and return to their favorite system. Why? CP/M 2.2 is a 
straightforward design, the DOS is located at high memory, 
and programs run from low memory just above a fixed entry 
jump table (8080 interrupt vectors set this design condition). 
When writing programs, little variation occurs between 
different systems to cause problems, and a lot of reference 
material is present to answer questions at non-technical 
levels. With 3.0, things start to get complex. Despite the 
fact that the same interface to the user is maintained, the 
operating system is in several parts, and data is moved into 
unknown parts using unknown algorithms. 

MSDOS starts right out differently, with the DOS in low 
memory and the user program area after the DOS. Large 
memory is now necessary, offsets are used to determine 
which bank of memory is active, and 64K is still the largest 
continuous segment of program space usable. What this 
means to the user is a more complex system to understand, 
forcing the user to purchase programs. True, more complex 
programs can be run, but writing your own programs in 
anything other than BASIC is almost impossible. This fact is 
borne out by the IBM user disks which contain about 60- 
70% BASIC programs (including the disk utilities). 

Not only should an operating system let you use programs 
(and be able to modify or understand them easily) but it 
must allow you to back them up (make copies), check 
density, catalog them, sort files, and many other disk utility 
functions. This is really where the battle is being 
fought -over utility functions. CP/M 2.2 has several built-in 
functions, and the open design allows for many utilities to 
support non-resident functions. The full operating system 
usually resides in less than 16K and can be used with only 
10K of utilities beyond the system tracks. Approximately 
170K is the normal free space on an 8* disk after I load my 
word processor and support utilities (250K after formatting). 
CP/M 3.0 uses a 32K system file plus system tracks (banked 
system) and may require up to 20K of support utilities. The 
same word processor and support programs would leave 
approximately 120K of 250K free. My favorite RAM DRIVE 
program only requires 4K of disk space and improves the 
speed to more than that of CP/M 3.0. 

When looking at speed, the 16 bit systems have a major 
drawback; they do 16 bit moves on an 8 bit wide system. 
IBM uses the Intel 8088, a 16 bit wide device that talks to 
the system 8 bits at a time. This equates to two accesses for 
each full accumulator function. Since most PC programs are 
only conversions of 8 bit programs, optimization to use the 8 
bit word moves is not always implemented. This means that 
two read or write functions must happen to load the 
accumulator. In true 8 bit systems only one read is needed 



for many of the same operations, or the 8 bit systems will do 
it in half the number of program steps. Consider again that 
text is in ASCII code (my 80% word processing) which is 7 
bits, and if 16 bit words are moved around, that wastes time. 
The only true test of speed is to try the system, since design 
is not the only thing to consider when comparing CPU 
capability. 

Dos Usage 

Having taken a diversion to discuss the different types of 
CPUs, let's get back to the main problem— that of which 
operating system to use. When 2.2 came out, most 
programmers were new at writing DOSs, and users helped 
upgrade the system as much as did the manufacturer. 
Things are different now. Competition is fierce, and 
professional programmmers abound. Like some doctors, 
many programmers want all the work for themselves with 
as little intervention from the user as possible. 
TURBODOS* . a high speed version of CP/M 2.2 and MP/M, 
is a good example of some programmmers' positions. The 
authors are not available, and hide out somewhere unknown 
to all but their agents. Very tight registration procedures 
are used (to prevent freebee systems), and little how-to 
information is given. Although this program works fine, I 
would rather use one of the look-alikes of CP/M that 
provides the source listing. Although I don't plan or 
recommend changes in DOSs for anyone but experts, my 
experience has shown that such lack of information will only 
cause problems in the long run. 

In order to make comparisons, you, the user, need to 
define the system's use. Unix is a programmer's operating 
system, best suited to professional programmers who use 
the operating system more than they do canned programs. 
When I make changes in a BIOS, the steps go something like 
this: 1) make change in BIOS, 2) ASM BIOS, 3) find errors, 4) 
change errors, 5) run program and find errors, 6) go back to 
1. Doing that 20 to 30 times in an afternoon can get pretty 
frustrating with slow, cumbersome systems. My Z-100 takes 
about a minute to boot, and if testing the system involves 
booting, that makes the loop about 10 to 15 minutes long. 
Small, short BIOSs that can be loaded quickly are great for 
developing new systems, as are programs that provide outer 
and inter rings for programs to run in. In the 32 bit 
versions, UNIX takes 250k of memory and several 
megabytes of disk space, which is definitly not a home 
system. Although this system provides a lot of tools 
(programs for special functions) for the programmmer, and 
has those rings that help develop new programs more 
quickly, these functions are all at the operating system 
level. Once inside a running program, most of the extra bells 
and whistles are lost. 

Not Getting Lost 

What I have been attempting to do in this article is to 
give enough background on operating systems to keep you, 
the user, from buying useless programs. Most of these 
programs are not useless in the right hands, but advertising 
agencies can make you believe a child could run their 
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program. For all those fathers who bought toys that said 
"any child can assemble this," only to find that the child 
would have to be a prodigy — have no fear; these same 
people are now selling computers! One of the reasons I am 
glad to be writing for The Computer Journal is its lack of 
irrelevant product reviews. The big, glossy computer 
magazines spend more time selling systems than supporting 
those products already sold and running. This is usually 
known as selling out to big business, which I believe they 
have done. There are some fairly honest reviews in these 
publications, but they are intended to sell. When it comes to 
computers (and life too), the biggest, newest, and most 
expensive are not always the best. There are several good 
2.2 systems for about $1500 that are better than the PC's 
which sell for $3800. Nothing surpasses an educated buyer 
when it comes to operating systems, but education must be 
tempered with a good understanding of your own limits, 
desires, and needs. 

A Parting Word 

This article was intended to arouse your curiosity, make 
you think about computing, help you start understanding 
DOSs, and show that the industry has a lot of room for 
improvement. Articles never appear as the writer had 
originally intended, nor as the reader would like them, but 
magazines are also forums for discussion and can start new 
and important changes when people take an active part. 
Remember, the first 8080 computer started as a how-to 
article... so start using your computer and write in with your 
discoveries and opinions. ' 



Threaded Language, continued 



Multi-user, continued 

formatted and after the devices have been connected in 
some manner. Sometimes we see references to "3A" and 
"3B" for these purposes. Levels five, six, and seven exist 
only within the computer and involve the way data is 
represented and its application, hence they are not really 
part of a network or communication system as such. 

In any multi-user system we will find level one protocols 
of some kind, usually level two, sometimes three, and 
perhaps four. We note in Cromemco's literature that they do 
consider all of these protocols as separate entities and 
that is good engineering practice where networks are 
concerned. * 



Cromemco and C-NET are trademarks of Cromemco, Inc. For 
additional information contact their marketing division at 280 
Bernardo Avenue, Mountain View, CA 9WtS. 



Interfacing Tips, continued 

specifications require that a logic be between a + 3 volts 
and a + 15 volts, and a logic 1 be between a - 3 and a - 15 
volts. Since there is such an allowable variation in voltages 
for each logic level, there was no need for regulation in this 
circuit. For this circuit I adjusted the converter output to 
generate a + 12 volts and a - 12 volts for the two logic 
levels. I have driven cables up to 25 feet using this 
configuration without any errors on the serial interface. 



•CAD: A5 00 








LDA SL 1 


unn««d*<J valuti 


0CAF: 69 04 








ADC • •04 




•CBi: 85 00 








STA SL 




0CB3: 90 02 








BCC OK 2 




•CBS: E6 01 








INC SM 




#CB7: 4C D9 0B 


0K2 






JMP ACC-> t 


»nd return th« inwf 




•• 


»/MOD 


»* 




#CBA: 05 AA AF 


CD 6E 


■C 






0CC0: A0 02 








LDY 0*02 ; 


g*t th* first two 


0CC2: Bl 00 


LOOP1 




LDA <5>.Y ; 


untignvd nuabtrt 


0CC4: 99 0C 00 








STA ACC.AL-2, 


Y 


•CC7: ce 








I NY 




0CC8: C0 06 








CPY 0*06 




•CCA: D0 F6 








BNE LOOP1 




0CCC: 20 0A 0B 








JSR 16«16«32 


I multiply th«M 


0CCF: A0 03 








LDY 0*03 ; 


«ov* C -> B 


0CD1: B9 14 00 


LDOP2 




LDA ACC.CIL.Y 




0CD4: 99 10 00 








STA ACC.B1L, Y 




0CD7: ee 








DEY 




0CD6: 10 F7 








BPL LDOP2 




0CDA: ce 








iny ; 


g»t th* third 


0CDB: Bl 00 








LDA <5>, Y 1 


unsigned number 


OCDD: 85 0E 








STA ACC.AL 




OCDF: CB 








INY 




0CE0: Bl » 








LDA <S), Y 




0CE2: 85 0F 








STA ACC.AH 




0CE«: 20 4B 0B 








J5R 32/16=16 


; divide by it 


0CE7: 20 09 08 








JSR DROP ; 


and ga to the 


0CEA: 4C 28 0C 








JMP MODISH ; 


•nd o< /MOD 




** 










0CED: 01 At A0 


A0 


BO 


0C 






0CF3: A0 01 








LDY »*01 i 


put tne address 


0CF5: Bl 00 








LDA <5> , Y ; 


m SCR 


0CF7: BS 19 








STA SCRH 




0CF9: 88 








DEY 




0CFA: Bl 00 








LDA (S>,Y 




0CFC: 85 18 








STA SCRL 




0Lf-t: 20 09 08 








JSR DROP 




0D0 1 : B 1 00 








LDA (S) . Y ; 


and *tore the 


0003: 91 18 








STA (5CR> . Y ; 


value in <SCR' 


0D05: CB 








INY 




0D06: Bl 00 








LDA (S).Y 




0D08 : 9 1 18 








STA (SCR).Y 




0D0A: 4C 08 








JMP DROP 






« 


*' 


.. 






0D0D: 97 AB Al 


A0 


ED 


0C 






0D13: A0 01 








LDY »»01 


put the address 


0D15: Bl 00 








LDA <S>,Y 


in SCR 


0D17: 85 19 








STA SCfcH 




0D19: 88 








DEY 




0D1A: Bl 00 








LDA <5>,V 




0D1C: 85 18 








STA SCRL 




0D1E: 20 09 08 








JSR DROP 




0D21: 18 








CLC 


and add the value 


0D22: Bl 00 








LDA <S>.Y 


to (SCR) 


0D24: 71 18 








ADC (5CR),Y 




0D26: 91 18 








STA (SCR).Y 




0D28: C8 
0D29: Bl 00 








INY 

LDA <S) , Y 




0D2B: 7] 18 








ADC ( SCR ! , Y 




0D2D: 91 IB 








STA iSCRJ.Y 




0D2F : 4C 09 08 








JNP DROP 






I. 


C 


« 






0D32: 02 C3 Al 


A0 


0D 


0D 






0D38: A0 01 








LDY 0*01 


put the address 


0D3A: Bl 99 








LDA <S),Y 


in SCR 


0D3C: 85 19 








STA SCRH 




0D3E: 88 








DEY 




0D3F: Bl 00 








LDA <5>,Y 




•D4i: 85 IB 








STA SCRL 




0D43: 20 09 08 








JSR DROP 




0D46: Bl 00 








LDA <S) , Y 


t and put the 


0D4B : 9 1 18 








STA <SCR).Y 


; one-byte value 


0D4A: 4C 09 08 








JMP DROP 


; in (SCR) 




I. 





.. 






0D4D: 01 C0 A0 


A0 


32 


0D 






0D53: A0 01 








LDY 0»01 


; put the address 


•D55E Bl 00 








LDA <S),Y 


I in SCR 


0D57: BS 19 








STA SCRH 




•D59: 88 








DEY 




•D5A: Bl 00 








LDA <S),Y 




0D5C: 85 18 








STA SCRL 




•D3E: Bl 18 








LDA (SCR>,Y 


; and get the value 


0D60: 91 00 








STA (S),Y 


1 4rom <SCR) 


0D62: C8 








INY 




0D63: Bl 18 








LDA ( SCR ) , V 




0D65: 91 00 








STA (S>,Y 




•D67: 60 








RTS 






** 


cm 


•• 






•D68: 02 C3 Ct 


A0 


4D 


0D 






0D6E: A0 01 








LDY 0*01 


1 put the address 


•D70: Bl 00 








LDA (S),Y 


I in SCR 


•D72: 85 19 








STA SCRH 




•D74: 88 








DEY 




0D75: Bl 00 








LDA (S>,Y 




•D77: 85 18 
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In conclusion, I hope you find this DC to DC converter 
circuit useful. I am interested in hearing about any unique 
applications that you might develop for it. Drop us a line and 
let us hear your ideas. ■ 
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BUILDING A CODE PHOTOREADER 

by R.O. Whitaker 




Figure 1: Reading the code into the computer. 

Introduction 

I don't key programs into my computer any more. Instead, 
I put the code sheets in my photoreader, pull the scanner 
down the code column, and in goes the code. But it is really 
not all that easy, because the code has to be written in 
"Computer Compatible Digits" (CCD). First, I had to learn to 
read and write them. What is a "Computer Compatible 
Digit?" Look at Figure 3. The elements of the code are 
binary weighted. Since each element corresponds to a 
respective bit of a computer word, the digit is "Computer 
Compatible," and no encoding is required for going to or 
coming from the computer. The digit is inherently 
hexadecimal, as indicated at the bottom of Figure 3. 

The first CCD was proposed by a gentleman over in 
Prague about 1955. Since then, several others have proposed 
digits of various configurations. The one I use was discussed 
in a paper published in an electronics magazine several 
years ago. All of the digits except six and seven can be 
written without lifting the pencil from the paper. All 
elements are equally conspicuous, and the elements of each 



ZERO~i 

«. TWO 



COMPUTER COMPATIBLE DIGITS 



EIGHTV 



y\° M 



-FOUR 



' \ I |\ \_L_l\/ A/1 AAAAA 

O I 2 3 4 5 6 7 8 9 10 II 12 13 14 15 

Figure 3: The composite digit at upper right consists of 
elements which are binary weighted. Each digit (bottom) is the 
sum of the elements represented. 



Figure 2: The reader. Electronics mounted beneath forward edge of 
platen. Seven zeroing pots shown in photo. 

digit are mutually contiguous. 

Figure 4 is a coding sheet with the code column on the 
left. The CCDs are formed by connecting the appropriate 
dots with a dull #2 pencil. 

Figure 5 shows the basic structure of the photoreader 
with a Code Sheet on the platen. The left edge of the sheet 
is placed against the stop to assure proper horizontal 
registry. The scanner slides on the guide rod. The optical 
fibers pass through holes in the faceplate (which slides over 
the code column). 

The scanner has a carrier associated with it which moves 
under the platen and keeps a pair of pilot lamps opposite the 
fiber ends. Light shines up through the transparent plastic 
platen and through the paper. Consequently, each fiber 
receives light except when it passes over a line of one of the 
digits. The other ends of the fibers feed to a series of 
photodetectors which are mounted on top of the scanner. 
The signals are then led by the ribbon cable to the 
electronics mounted under the forward edge of the platen 
(see Figure 2). 

To operate the photoreader, insert the code sheet and 
move the scanner to the top of the column. Lift sense switch 
80 on the computer. Draw the scanner down the page. Drop 
SSW 80, remove the code sheet, and insert the next one. 

The fiber optic sensors scan along the dotted lines of 
Figure 6. Note that the ID (indicium) sensor senses the 
presence of indicia in the column at the right. The action is 
as follows: 

1. When the ID sensor leaves an indicium, it causes the "B" 
register of the computer to be nulled. The word being 
scanned will be assembled in this register. 

2. While the ID sensor is in the "A" region of Figure 6, the 
other six sensors look for their respective lines. Each one 
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that sees its line sets its respective bit in register B. 
3. While the ID sensor is in region B, the 8-sensor looks for 
the 4-line. If it sees the 4-line, it sets the 4-bit in register B. 
Similarly, the 80-sensor looks for the 40-line and sets the 40-bit. 
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4. When the ID sensor drops from the indicium of region B f 

the word in register B is delivered to memory and to the 

display. Register B is reset before scanning the next word. 

The "2-lines" were not included in Figure 6, but appear in 

Figure 4. Note that each 2-line bears a 

crossbar, which causes the 2-sensor to 

see the line even if the paper is off a 

millimeter or so in horizontal registry 

or if I was too sloppy in writing it. 
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Figure 4: Coding sheet. 



The Flowchart 

Refer to the flowchart in Figure 7. 

Blocks one to four initialize the system. 

Blocks five to end constitute the RUN 
loop in which the computer operates 
while characters are being read. 

Blocks six to nine constitute the A 
loop, where the computer operates as 
long as the ID sensor is in region A. 

Blocks ten to thirteen are the B loop 
where the computer operates while the 
ID sensor is in the B region. 

Blocks fourteen to end terminate the 
reading of a pair of digits. 



The blocks will now be discussed in order. 
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SCANNING PATHS OF SENSORS 

11 I ' ! ! 




^-INDICIUM 



Figure 6: Scanning paths of the sensors. Paths are vertical 
dotted lines. The "two" lines of several digits are shown. 



1. The computer twiddles until SSW 80 is lifted. This 
prevents anything from being read until I have zeroed the 
pots, given the computer a loading address, have the code 
sheet in place, and am ready to read. 

2. As soon as SSW 80 is raised, the computer drops to here. 
If the first indicium is not yet seen by the ID sensor, the 
computer continues to twiddle. 

3. As soon as the top indicium (see Figure 3) is sensed by 
the ID sensor, the computer drops to here. If the first 
indicium is not yet seen by the ID sensor, the computer 
continues to twiddle. 

4. If SSW 80 is still up, the computer drops to here. It 
checks to see if the indicium is still visible. Yes. It twiddles 
in a new loop. 

5. As soon as the ID sensor drops off the top indicium, the 
computer drops to here. This block nulls the B register 
before the word being read is assembled into that register. 
The "PWD" stands for "Processor Word." The word is 
assembled in register B and moved to memory. 

6. Checks to see if SSW 80 is still up. No. It aborts the scan. 

7. 8, and 9. Checks to see if the SSW 80 is still up. Yes. 
Brings in the "Read Word" (RWD) sensed by the reader at 
any particular instant and dependent upon where the 
scanner happens to be in relation to the digit pair. Merges it 
into B. Repeats Steps six through nine until the ID sensor 
senses the presence of the second indicium. Note from 
Figure 6 that this loop will operate for region A. It will 
cause the 1, 2, 8, 10, 20, and 80 lines to be read. For each line 
present, it will cause its respective bit in register B to be 
set. Note from Figure 6 that a 1 or 8 line can hardly be 
mistaken for a 2-line. 

10. Once the ID sensor sees the second indicium, the 
computer drops to here. 

11, 12, and 13. This is the B loop. The computer stays here 
as long as the ID sensor sees the second indicium — as long 
as the sensors are in region B of Figure 6. The 80 and 8 
sensors look for the 40-line and the 4-line respectively. The 
other sensors do nothing. If the 80-sensor sees the 40-line, 



the 40-bit is set in register B. If the 8-sensor sees a 4-line, 
the 4-bit is set. 

14, 15, and last. When ID drops off the second indicium, the 
word stored in register B is sent to memory and to the 
display. The memory pointer is incremented. 

At the completion of scanning, I drop SSW 80 to prevent 
any more reading. A copy of the program (written for an 
8080 computer) will be forwarded upon request. Send three 
20 cent stamps to the author. 

Electronics 

Study Figure 8 for a moment. The transistors and 
associated components were mounted on a piece of 
perfboard under the platen, as shown in Figure 2. Pots were 
mounted so that they could be easily adjusted from the 
front. The LEDs were placed beside their respective pots. 
Since there is no 4-sensor, the ID sensor occupies the 4 slot. 

The Schmitt trigger (7413) was installed on the output of 
the ID sensor to eliminate multiple readings associated with 
noise signals when the sensor moved over the edge of an 
indicium. The pots permit the channels to be "zeroed." G.E. 
specifies three volts for proper operation of the 
photodarlingtons. Zener Z-l drops the five volt supply to 
this level. 

Construction 

I used scrap plastic obtained from a local plastics dealer 
for the frame parts and the platen. It seems that plastic is 
transparent to infared radiation of the wavelength to which 
the sensors are sensitive. Hot glue was used to hold minor 
components in place. The guide rod on which the scanner 
slides was an iron rod taken from an old Selectric 
typewriter. It was already ground smooth, permitting the 
scanner to slide easily upon it. Any smooth steel rod about 
4mm in diameter should do. Plastic Crofon optical fibers 
lmm in diameter were used. The General Electric GFOD-1B 
photodarlington was designed to work with these fibers. 
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The open ends were polished with jeweler's rouge, and fit 
flush with the bottom surface of the faceplate. A piece of 
Scotch tape protected the exposed ends from abrasion. The 
holes for the fibers were drilled with a Unimat lathe, which 
permitted them to be positioned very precisely. However, 
that should not be necessary. If the digits are about 1.5cm in 
width, then a scale and centerpunch should allow the holes 
to be positioned with sufficient accuracy. 

I used two six volt, 200ma pilot lamps for the light source, 
and surounded them with a reflector made from a beer can. 
The two bulbs are powered by five volts regulated. I used a 
five volt bench supply to power the reader. Power could also 
be drawn from the host computer, or a supply could be 
mounted on the reader. 

Zeroing the System 

To aid in leroing the system, I put two horizontal lines 
across the top of the code column (see Figure 4). The first is 
so thin that the sensors do not trip on it. The second is just 
barely dark enough to trip the sensors. The pots were then 
adjusted so that their respective LEDs did not light for the 
first line and did light for the second. The only requirement 
for proper reading is that the lines of each digit be darker 
than the second line. 

Paper 

At first I used a pad of dime store paper that was cross- 
hatched into 5mm squares. Any paper used should be free of 
clay — clay is opaque to infrared. I now use preprinted forms. 
They are more expensive and don't work a bit better, but 
they do make a more favorable impression upon the 
impressionable. Dots on the form are positioned so that the 
procedure of writing the code is reduced to connecting the 
appropriate dots with fairly straight lines. 

Future Models 

Small diameter sensors are now available which can be 
mounted in the read head, eliminating the optical fibers. 
Should I build another reader, I will go that route. It would 
probably be better to replace the lamps with infrared 
emitters of the semiconductor type designed to work with 
the detectors. The two ordinary bulbs I used worked fine, 
but ideally, an emitter with a lens would focus radiation 
upon the paper directly opposite its respective sensor. 

Where to Get the Parts 

The detectors should be procurable from your local GE 
distributor. The transistors and Schmitt triggers can be 
purchased from any Radio Shack or electronic parts store, 
or from a mail order company such as Jameco. I got my 
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Figure 8: Electronics. 



Crofon optical fibers from Edmund Scientific. Crofon is 
made by DuPont, and you can probably obtain it from a local 
plastics distributor. Check with GE. The matching 
connectors for the GF0D-1B were the most difficult parts to 
obtain. My source made me buy far more than I needed, and 
at an astronomical price. Check with your GE distributor 
regarding matching connectors, or check with me. If there is 
enough interest, I'll stock parts for resale at a nominal price. 
Hot glue or cement are viable alternatives to the 
connectors, but are not as fancy looking. The connectors are 
also considerably more convenient if you have to take the 
rig apart. 

I have applied for a patent on the reader, and will sell you 
a non-exclusive license to build one unit for your own use. 
The cost to you will be one stamped, self-addressed 
envelope. The stamp should be of the 20 cent variety. And 
uncancelled. If you don't have one, let it go. Maybe I can find 
one around here. B 

R.O. Whitaker 
i719 Squire Drive 
Indianapolis, IN J,6M 



Customer Support Survey 

In order to improve customer support and aid users in thier shopping within the microcomputer 
industry, TCJ will publish user experiences with vendors. Send us your candidate for the best and 
worst vendor, along with your supporting information. 
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HELP! 

The Readers' Column 



Readers, this is your column! We encourage you to communicate with other readers by using this space to ask 
for their help with your problems, and to reply to the problems presented here. Where possible, the editors 
will respond to specific questions regarding TCJ articles. Otherwise, you can provide the "HELP" by sending 
your solutions for publication to PO Box 1697, Kalispell MT 5990S. We will try to keep the lead time short for 
.a rapid exchange of information. Let us hear from you! 



interfacing a TI 99YA with a 



Dear Computer Journal, 

I need information on 
Teletype model 28. 

Wilbur Kespert 

Florida 

Ed: Readers, can you help? 



Dear Computer Journal, 

Do you know how I could upgrade a TRS-80 MC-10 micro 
color computer to 64K using 4164 chips? Radio Shack makes 
a 16K plug-in module, but no 64K module. 

Bryan Lepkowski 

New York 

Ed: Readers, can you help? 



Dear Mr. Rose, 

I have read your three part article on building a print 
spooler with great interest. I am seriously considering the 
project. I do have one question. I have an Apple II + and 



some experience programming the 2716. I would like to 
know how I can handle the Z80 op codes with my "Big Mac" 
assembler. Could I enter the machine code directly into 
memory and then into the 2716? If so, could you provide me 
(and perhaps other readers) with a memory dump for the 
operating program? 

Thanks, 

Hugh McEntire 

California 



Ed: Although I don't have an Apple II + myself, I asked 
someone local here about the "Big Mac" assembler and he 
informs me that it can only handle the 6502 op codes and 
will not assemble those for the Z80. However, the program 
is not a long one, and your idea of entering it directly in 
machine language should be quite feasible. I made a hex 
dump of the operating program and am including it for you 
here. 

Thanks for writing and good luck with your project. 

Regards, 

Lance Rose 

Technical Editor 
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The Computer Journal will carry Classified Ads. The rate is $.50 per word, minimum charge 
$7.50. All Classified Ads must be paid in advance, and will be published in the next available 
issue. No checking copies or proofs are supplied, so please type your ad or print legibly. 
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The Bookshelf 



CP/M Primer 

Helps microcomputer veterans mod novices alike find the answers about CP/M is > 
complete, one-itop aourcebook that's > Sams best-seller! Gives you complete CP/M 
terminology, hardware and software concepts, startup details, and more for this popular 
8080/8085/Z-80 operating system. Helps you begin using and working with CP/M 
immediately, and includes a list of compatible software, too. By Stephen Murtha and 
Mitchell Waite. 96 pages, SVixll, comb. ©1980 $16.95 

Soul of CP/M: Using and Modifying CP/M's Internal 
Features 

Teaches you how to modify BIOS, use CP/M system calls in your own programs, and 
more! Excellent for those who have read CP/M Primer or who otherwise understand 
CP/M's outer-layer utilities. By Mitchell Waite. Approximately 160pages. 8x9Vi, comb. 
©1»83 ,18.96 

The S-100 and Other Micro Buses (2nd Edition) 

Examines microcomputer bus syestems in general and 21 of the most popular systems 
in particular, including the S-100. Helps you expand your computer system through a 
better understanding of what each bus includes and how you can interface one bus with 
another. By Elmer C. Poe and James C. Goodwin, II. 208 pages, 5'/ix8'/i, soft. ©1981J9.95 



Scientific Data Communications 



Interfacing & 
Experiments 

This book introduces you to the principles involved in transferring data using the 
asynchronous serial data-transfer technique. It focuses on using the universal 
asynchronous receiver/transmitter (UARTI chip in order to help your understanding of 
communication chips. Explores operation of teletype-writer interfaces and serial 
transmission circuits. With experiments and circuit details. By Peter R. Rony. 160 pages. 
B'/ixS'A. soft. ©1979 $7.95 

Active-Filter Cookbook 

A practical discussion of the many active-filter types and uses, written by one of Sams' 
moat popular authors. Teaches you how to construct filters of all types, including high 
paaa. low-pass, and bandpass hiving Bessel, Chebyshev, or Butterworth response. Easy to 
understand- no advanced math or obscure theory. Can also be used as a reference book 
for analysis and synthesis techniques for setive-filter specialists. By Don Lancaster. 240 
pages, 6Vix8Vi, soft. ©1975 $14.95 

Regulated Power Supplies (3rd Edition) 

Newest, most comprehensive discussion you'll find of regulated power supph'es, 
including their internal architecture and operation. Thoroughly explains how to use 
regulation in your designs and projects when the need arises, and discusses practical 
circuitry and components. A valuable book for any technician or engineer involved in 
servicing or design. By Irving M. Gottlieb. 424 pages. 5Vix8Vi, soft. ©1981 $19.95 

TTL Cookbook 

Popular Sams author Dan Lancaster gives you s complete look at TTL logic circuits, the 
most inexpensive, most widely applicable form of electronic logic. In no-nonsense 
language, he spells out just whst TTL is, how it works, and how you can uae it. Many 
practical TTL applications are examined, including digital counters, electronic 
stopwatches, digital voltmeters, and digital tachometers By Don Lancaster. 336 pages, 
B'AxS'/i. soft. ©1974 $12.95 

IC Op-Amp Cookbook 

An informal, easy-to-read guide covering basic op-amp theory in detail, with 200 
practical, illustrated circuit applications to reflect the most recent technology. JFET and 
MOSFET units are shown in both single and multiple formats Includes manufacturers' 
data sheets, and lists addresses of the companies whose products are featured. By Walter 
G Jung. 480 pages. S'/ixS'/i, soft. ©1980 $15.95 



IC Converter Cookbook 

Discusses and explains data conversion fundamentals, hardware, and peripherals. A 
valuable guide to help you understand and use dVs and a/d converter applications. Includes 
manufacturers' data sheets. By Walter G. Jung. 576 pages, S'AxSVi, soft. ©1978 $14.95 

IC Timer Cookbook (Second Edition) 

Learn more ways to use the IC timer in this easy to use second edition that includes 
many new IC devices with ready to use applications in practical, working circuits. AU 
circuits and component relationships are fully defined and discussed for clarity. By Walter 
C. Jung. 384 pages. 6Vix8'/i. soft. ©1983 $17.95 

The Programmer's CP/M Handbook 

An exhaustive coverage of CP/M-80* . its internal structure and major components is 
presented. Written for the programmer, this volume includes subroutine examples for 
each of the CP/M system calls and information on how to customise CP/M - complete with 
detailed source codes for all examples. A doxen utility programs are shown with heavily 
annotated C-language source codes. An invaluable and comprehensive tool for the serious 
programmer. By Andy Johnson-Laird, 750 pages, 7'/ix9'/ii, softbound $21.95 

Interfacing to S-100 (IEEE 696) Microcomputers 

This book is a must if you want to design a custom interface between an S-100 
microcomputer and almost any type of peripheral device. Mechanical and electrical design 
is covered, along with logical and electrical relationships, bus interconnections and more. 
By Sol Lines and Mark Gareti, 322 pages. 6Vix9'*, softbound $16.95 

Microprocessors for Measurement and Control 

You'll learn to design mechanical and process equipment using microprocessor-based 
"real time" computer systems. This book presents plans for prototype systems which 
allow even those unfamiliar with machine or assembly language to initiate projects. By 
D.M. Auslander and P. Sagues. 310 pages. 7 3/8x9 1/4, softbound $15.99 

Osborne CP/M® User Guide (Second Edition) 

A new revised edition which includes expanded sections on CP/M* 86 and CP/M* 80. as 
well as CP/M* • relationship to assembly language programming, MP/M* and CP/NET* 
operating environmenta. By Thom Hogan. 292 pages, 6'/iiS'A, softbound $15.95. 

Discover FORTH 

Whether you are a beginner seeking information on this multi-faceted programming 
language or a serious programmer already using FORTH, this book is a reference that 
should not be overlooked. Long considered a computer language of building blocks, 
FORTH has been optimised for speed and requires little computer support. By Thom 
Hogan, 146 pages, 6Vix9 'k, softbound $16.95 

68000 Assembly Language Programming 

Each of the 68000's instructions is individually presented and fully explained in this 
aasembly language tutorial. For experienced programmers, this book is also a complete 
reference to the 68000 instruction set and programming techniques. By Lance A 
Leventhal, 614 pages, 6Vix9'A , softbound $18.96 

Z8000® Assembly Language Programming 

This book is filled with real-world programming examples, sample problems, and 
troubleshooting hints that will guide the reader to mastery of this powerful new 16-bit 
"super chip". The entire Z8000* instruction set is described in detail. By Lance A 
Leventhal. Adam Osborne, and Chuck Collins. 928 pages. 6'Ax9 'A, softbound $19.99 

The 8086 Book 

Anyone uiing, designing, or simp); interested in in 8086-based system will be delighted 
by thi* book's Mope utd authority. As the 16-bit microprocessor gains wider inclusion in 
■mil] computer., this book becomes invslusble ss s reference tool which covers the 
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timing, architecture and deeign of the 808«. as weU >• optimal programming technique!. 
Interfacing, special feeturee, ud more. By RuaaeU Rector and George Aleij, 824 pagei. 
t'Hit'k. aoftbound ,,6W - 

Z80* Assembly Language Programming 

Programming examples Uluatrate aohware development concepts and actual aaaembly 
language uaage. More than 80 aample programming problems with aolutioni and a 
complete Z»0« inatruction aet reference table. By Lanee A. Leventhal. 640 pagei. 
6'Art'A. aoftbound 



$18.86 



8080A/8085 Assembly Language Programming 

Mora quality programming example! and inatruction aeu than can be found in any 
other book on the subject. Information on aeeemblere, program loopa. code converaion and 
more. A muat for 8080A/80805 programmer!. By Lance A Leventhal. U8 pagei. 6Vix9V 



aoftbound. 



. $18.95 



Microprocessor-Based Robotics 

' Introduces you to robotics -a dynamic new Geld of acience that uiei your computing 
and electronic talenta aa well as your mechanical and electrical knowledge. First. you'U 
learn the meehanica of robot hands, arms, and legs; then, tactile sensing, motion snd 
attitude aenaing. and viaion systems After thst, you learn controlling with 
mieroproeeeeors and BASIC programs, and finally, you learn to control the entire robot 
system with voice commends! Fascinating and nof machine apecific. By Mark J. Robillard. 
224 pages, B'/ixll. aoftbound * 16 - 95 

TV Typewritter Cookbook 

Shows you how to quickly and easily project words and picture! from s common, 
microprocessor-baaed system onto an ordinary TV aet. You'U be introduced to TVT 
communications by best-selling author Don Lancaster, who discusses basic TVT system 
design, memory typei. interface circuitry, hard-copy output, and color graphics. By Don 
Lancaster, 266 pagea, 5Vi 18 V. , aoftbound * 129s 

Microcomputer Matb 

A step-by-step introduction to binary, octal, and hexidecimal numbers, and arithmetic 
operations on aU type! of microcomputer! Excellent for serious BASIC beginner! aa weU 
aa aeeembly-language programmer!. Treat! addition and aubtraction of binary, multiple 
preciaion and floatingpoint operation!, fraction! and acaling, flag bit!, and more. Many 
practical example! and eelf-tests. By William Barden, 160 pages. S'/.x8Vi, eoftbound.il. 95 

Understanding Digital Logic Circuits 

A working handbook for lervice technicians and others who need to know more about 
digital electronic! in radio, television, audio, or related areas of electronic troubleshooting 
and repair. You're given an overview of the anatomy of digital-logic diagrams and 
introduced to the many commercial IC packages on the market. By Robert G. Middleton. 
392 pagea, o'/iiS'/i, aoftbound 118.95. 

CMOS Cookbook 

One of the beit-seUing technical books on the market, this cookbook give! you a aohd 
understanding of CMOS technology and its application to real world circuitry. Explains 
how CMOS differ! from other MOS designs, how it's powered, and what its advantages 
are over other eonatructions. The final chapter ibowa you how to put all preceding 
information to work conatructing aeveral large-acale, working initrument!. Include! a 
mini-catalog of more than 100 device!, with pinouti and application note!. By Don 
. Lancaeter, 418 pagea. 5Vix8Vi , aoftbound » 13 - 96 



Real Time Programming: Neglected Topics 

This book presents an original approach to the Urma, axilla, and standard hardware 
devices seeded to connect a computer to numerous peripheral devices. It dietUls technical 
knowledge used by hobbyists and computer scientist! alike to useable, comprehensible 
methods. It explains such computer and electronics concepts aa simple and hierarchical 
interrupts, ports. PlAs, timers, converters, the sampling theorem, digital filters, closed 
loop control systems, multiplexing, buses, communication, and distributed computer 
systemi. By Caxton C. Foster. 190 pages, 6 'Art'*, softbound *995 

Interfacing Microcomputers to the Real World 

Here ii a complete guide for using s microcomputer to computerise the home, office, or 
laboratory. It shows how to design and build the interfaces necessary to connect a 
microcomputer to real-world devices. With this book, microcomputer! can be programmed 
to provide fast, accurate monitoring and control of virtually all electronic function! -from 
controlling boueelighta. thermostats, aensora. and ewitehea, to operating motors, 
keyboards, and displays. This book is baaed on both the hardware and software principles 
of the Z80 microprocessor (found in several minicomputers. Tandy Corporation's famous 
TRS-80. and othera). By Murray Sargent III and Richard Shoemaker, 288 pagei. t'kii'k, 
aoftbound mU 

Mastering CP/M 

Now you can use CP/M to do more than just copy files. For CP/M users or systems 
programmers -this book takes up where our CP/M handbook leaves off. It will give you 
an in-depth understanding of the CP/M modules such aa, CCP (Conaole Command 
Processor). BIOS (Basic Input/Output System), and BDOS (Baaic Diek Operating Syetem). 
Find out how to: incorporate additional peripherals with your system, use console 1/0. use 
the file control block and much more. This book includes a apecal feature -a library of 
useful micros. A comprehensive set of appendices is included aa a practical reference tool. 
Take advanUge of the veraatility of your operating systemi By Alan R. MUler. 898 pages, 
6 'x9 ■, softbound %ltK 

Designing With the 8088 Microprocessor 

If you're sesrehing for an introduction to software and hardware deaign uaing the 8088. 
you wUl find this book to be indispensable. After deeeribing the 8088, the author leads you 
step-by-step through the complete system design of a powerful, yet inexpensive, single- 
board controller. Thia eingle-board controUer design Ulustrates s typical application of the 
8088, uaing «4K-bit dynamic RAMs, the 8208 VLSI dyncamic RAM controUer. and etate-of 
the-art peripherals such aa the 8254 programmable interval timer and the 8274 multi 
protocol aerial controUer. ControUer software design is alao described in detail -from the 
basic aaaembly language teat programs to high-level language interrupt control 
procedures. In addition, the 80188 aoftware and hardware enhancements are briefly 
deacribed. By John ZarreUa, 804 pages. «'x9", softbound H9.95 

FORTH Tools, Volume One 

FORTH Tools is a eomprehenaive introduction to the new international F0RTH-83 
Standard and all ite extensions. It gives careful treatment to the CREATE-DOES 
conatruct. which u uaed to extend the language through new classes of inteUigent dau 
structures. FORTH Tools gives the reader an in-depth view of input and output, from 
reading the input atream to writing a simple mailing Ust program. Each topic ia preeented 
with practical examples and numerous Ulustrstions. Problems (and solutions) are provided 
at the end of each chapter. FORTH Tools is the required textbook for the UCLA and IC 
Berkeley extenaion courses on FORTH. By Anita Anderson and Martin Tracy, 218 pages. 
6'A i8'A . softbound I200 ° 
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Books of Interest 



Interfacing Microcomputers to the Real World. 

by Murray Sargent III and Richard L. Shoemaker. 

Published by Addison- Wesley, Inc. 

288 pages, 6'A x 9'A, softbound, $16.55. 

This book covers interfacing using the Z80 
microprocessor. It starts with the elementary principles of 
microelectronics and then uses them to explain more com- 
plex interfacing concepts. The examples are useful, practical 
applications including interrupts, real time clocks, stepper 
motors, A/D and D/A conversion, an interface board, tran- 
smitter and receiver circuits (garage door opener), and BSR 
carrier wave control circuits. 
The contents are as follows: 

•Chapter 1 Introduction to Digital Logic. The 
Diode, TTL Gates -AND, NAND, OR, NOR, 
XOR, The transistor as a Switch, TTL In- 
put/Output Characteristics, Flip-flops, Clocks, 
Counters, and One shots and Shift Registers. 
•Chapter 2 Programming the Z80 

Microprocessor. Machine and Assembly 
Languages, Moving Data in 8-bit Registers and 
Memory, Manipulating Data -INC, SET, ADD, 
AND, 16-bit Registers and Memory Pointers, 
Jumps, Conditional Jumps and Subroutines, 
Shifty Registers, Input/Output, The Stack and A 
Tiny Operating System. 

•Chapter 3 Processor-Input/Output Inter- 
facing. The Forty Pins, Input/Output Ports, In- 
put/Output Address Decoding, Interrupts, Real 
Time Clock Interrupt Scheme, Direct Memory 
Access (DMA), and I/O Example: Multiplexed 
Keypad/Display. 

•Chapter 4 Controlling/Monitoring Various Real 
World Devices. Switch Closures, Input and Out- 
put, Digital to Analog Conversion, Analog to 
Digital Conversion, Signal Averaging and Lock- 
in Detection, Waveform Generation and 
Recognition, Motor Control, and Raster 
Displays. 

•Chapter 5 Serial Input/Output. Parallel/Serial 
Conversion: the USART, RS232 and Current- 
loop Conventions, Modems, Computer-Computer 
Communication Methods, and Rf, Fiber Optics, 
and Power-line Carriers. 

•Chapter 6 Microcomputer Systems. RAM, 
EPROM, Hard and Floppy Disks, Small Con- 
troller Systems, Z80 Computer Busses, and 
Examples of Larger Microcomputers. 



•Chapter 7 Software. Editors, Assemblers, 
Linkers, Debuggers, Interpreters and Compilers, 
Disk Operating Systems, and Computer Hierar- 
chies. 

•Chapter 8 Hands-On Experience. TTL Logic, 
Assembly Language Programming, Building an 
Interface Board, Looking at CPU Signals, In- 
terrupts and Real-time Clocks, Using I/O Ports 
as Device Controllers, Experiments with DACs 
and ADCs, Stepper Motors, and Serial and Com- 
puter-computer Communications. 
•Appendices include the following: Z80 
Buses -S-100 Bus Definition, TRS-80 Bus 
Definition, STD Bus Definition; Computer-Com- 
puter Communications- TRSCOM; The 
DEMON Monitor; Tiny Operating System; 
Keyboard/Display Routines; and Z80 Instruction 
Codes. 
The entire book is very good, but I found the chapter on 
hands-on experience especially helpful. This chapter starts 
with two quotations, "Experiments should be reproducible; 
they should all fail in the same way," and "Experience is 
directly proportional to the amount of equipment ruined." 
These are attributed to Murphy, but anyone who has spent 
much time at the bench should agree. An example of the 
practical advice is found on page 190, where they say 
"Always wire up your circuits with the power OFF. When 
you are finished wiring, double check that the circuit is 
wired correctly BEFORE you turn the power on. The alter- 
native is to check the circuit after the power is on and to ob- 
serve which components have smoke rising from them." 

This book is a good blend of theory and practical ap- 
plications for anyone who wants to interface their Z80 
microcomputer to the real world. ■ 

Art Carlson 



RPN (Reverse 


Polish Notation) 


RPN (also known as postfix notation) is commonly used on 
stack oriented machines, and makes complicated algebraic 
expressions easier to enter. Using RPN, the operator is 
listed after the operands instead of between them. For 


examp e. g^ no t a tion 




RPN 


3x2 




3 2 x 


4 + 5 




4 5 + 


7 / 3 




7 3 / 


2 + 4/3 




2 4 + 3/ 
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Programmable 4K RAM Robot 

A new, low cost, programmable 4K RAM robot introduced 
by Stock Model Parts is controlled through its seven 
function teach pendant. The robot includes an onboard 
CMOS static RAM 256x4 sequencer. Applications include 
school science projects, robotics courses or personal 
enjoyment. Of special significance is the fact that the robot 
is programmable through any of the popular 
microcomputers (with parallel interface) to gain experience 
about how real robots are controlled. Buttons on the teach 
pendant can be used to program the robot to go forward, 
right, left, pause, sound a buzzer, light a LED lamp, or 
repeat a program continuously. 




The three wheeled robot, called the Memcon Crawler, is 
offered in kit form. Included are four pages of easy to follow 
instructions which make it possible to complete the 
mechanical assembly in about two hours. All electronic 
elements are contained in two pre-soldered and pretested 
printed circuit boards. The 5V« " diameter, 2Vi " high robot 
consists of 51 major components plus over 140 fasteners. 
Among the major parts are two DC motors, rugged blue 
tinted molded body parts, plus two geartrain assemblies. It 
is powered by one nine volt and two AA batteries. 

The kit is available for $79.97 postpaid from Stock Model 
Parts, Division of Designatronics, Inc., 54 South Denton 
Ave, New Hyde Park, New York 11040. ■ 

MicroSolutions' New UniForm 

MicroSolutions has developed a product called UniForm, 
which makes it possible to read and write 5 V* " CP/M disks 
in a number of popular formats. UniForm is a program that 
allows the user to redefine the operating format of the "B" 
drive of their CP/M computer, opening up a whole new 
avenue of communication between systems with varying 
disk formats. 

With UniForm, the user has the ability to take a blank 



5'A " disk and initialize it to any of the supported formats. 
For example, you could initialize a disk on your KayPro II in 
the Morrow MD2 format, set your operating format to MD2, 
write a letter using WordStar, and mail it to someone with 
an MD2 who could use WordStar on their machine to read 
it. UniForm works with any files, text, data, or machine 
code. It does nothing to alter the files at all, and is 
transparent to the user or program while in operation. 
Programs with no video attribute or hardware dependent 
routines can be transferred between machines and run (such 
as PIP, or MBASIC programs if properly written). 

UniForm is completely menu driven and self prompting, 
with English mesaages in response to invalid entries. The 
program was written with a heavy emphasis on ease of use, 
and as a result, is so straightforward that a manual is 
practically unnecessary. A manual is provided with 
UniForm. It explains the program simply and accurately, 
and provides a complete walk-through of all functions for 
those who desire it. 

UniForm is able to support almost all 48 track per inch 
soft sectored CP/M formats. Since it is hardware dependent, 
versions are available for several of the most popular 
computers. Currently, there are eleven versions of 
UniForm: Actrix; Epson QX-10, KayPro II, 4, 4-84, and 10; 
Morrow Micro Decision; NEC PC-8801; Osborne I (DD); 
Televideo TS 803/TPC-l; and Zenith Z-100 CP/M-85. Some 
computers can support more formats than others because of 
internal hardware characteristics; for example, the Morrow 
MD UniForm supports 20 single sided formats, 18 double 
sided formats, and one non-CP/M format (the 
MSDOS/PCDOS). For a complete list of the formats 
available with any of these versions, write to 
MicroSolutions, 125 South Fourth St, DeKalb, IL 60115. 
UniForm is available from MicroSolutions for $69.95. ■ 
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EXERCISER! 



S) 



Disk 



*nu 



DRIVE 






fir 



2000 



r £STE R 



KOTO 



PC 



INC. 



m HYST »QTor 
EYE R£A D 







i 



F%f 



71 



- SHOWS SPEED AND SPEED 
AVERAGE! 

- HYSTERESIS CHECK BUILT IN 

- SELECT 5" 48, 96, 100 TPI, OR 
8" 48, TPI 

- POWER "Y" CABLE=$10 
DRIVE DATA CABLE =$20 



ALIGN DRIVE IN 10 MINUTES! 

Use with scope and alignment disk (SS $49, DS $75) 

- SINGLE KEYSTROKE FOR 
ALL ALIGNMENT TRACKS 

- JOG KEYS-MOVE TO ANY 
TRACK 

— INCLUDES "OSBORNE" 
TYPE POWER HOOKUP 

— RUNS ANY STANDARD 34 
PIN (5") OR 50 PIN (8") DRIVE 

USED BY: IBM, ARMY, NAVY, RCA, ETC... 

ex 2000 $299 

FREE Air Freight on Prepaid Orders. COD: Add $5 Plus Shipping 

PROTOPCinc. CALL NOW! 6 i 2 -644-4660 
2439 Franklin, St. Paul, MN 55114 



